JavaScript: установить свойство или вернуть значения?(простой способ) - PullRequest
2 голосов
/ 14 июля 2011

Я создал короткую функцию для установки и извлечения значений из объекта (> получения баллов по имени), но я не уверен, действительно ли мое решение действительно разумно.

Какие модификации вы рекомендуете для совершенствования этого запроса?

var points = {}; //global var

function getPoints() {

    var args = arguments, name;

    // set points or return them!

    if (typeof args[0] == 'object') {

        name = args[0].name;
        points = { name: args[0].points };

    } else {

        name = args[0];
        return points.name;
    }
}

  //set:
  getPoints(name: "John", points: 0)    //set points (0)
  getPoints(name: "Pamela", points: 2 ) //set points (2)

  //return:
  getPoints("John")    //returns > (0)
  getPoints("Pamela")  //returns > (2)

Ответы [ 3 ]

1 голос
/ 14 июля 2011

[ edit ] предыдущий ответ был неправильным: не упомянул невозможность getPoints("John")

Насколько я понимаю, вы пытаетесь объединить get и set в одинфункция.

Вы можете использовать Points constructor function здесь, что-то вроде:

var Points = function(name,points){
   this.name = name || '';
   this.points = points || 0;
   if (!Points.prototype.get){
      var proto = Points.prototype;
      proto.get = function(label) {
         return this[label] || label
      };
      proto.set = function(){
        if (arguments.length === 2){
           this[arguments[0]] = arguments[1];
        } else if (/obj/i.test(typeof arguments[0])){
           var obj = arguments[0];
           for (var l in obj){
              if (obj.hasOwnProperty(l)){
               this[l] = obj[l];
              }
           }
        }
        return this;
      };
   }
}

var john = new Points('John',0), mary = new Points('Mary',2), pete = new Points;
pete.set({name:'Pete',points:12});
john.set('points',15);
//two ways to get a 'points' property
alert(john.get('points')+', '+pete.points); //=> 15, 12
1 голос
/ 14 июля 2011

Единственная проблема, которую я вижу, состоит в том, что значение points перезаписывается каждый раз, когда вы звоните getpoints, т. Е.

getPoints({name :"John", points: 0}); // points = {"John": 0}
getPoints({name:"Mein", points:1}); // points = {"Mein":1}

Также имя сбивает с толку.Моя версия будет:

var points = {};
function getOrSetPoints(){
    if(typeof arguments[0] === "object"){
        points[arguments[0].name] = arguments[0].points;
    }
    else
        return points[arguments[0]] || arguments[0] + ' not set'
}
1 голос
/ 14 июля 2011

Я бы создал другую функцию для геттера и сеттера. Функция getPoints, которая также устанавливает баллы, не имеет смысла и может сбить с толку ppl:)

...