Есть ли разница между использованием этого и прототипа в Javascript здесь? - PullRequest
5 голосов
/ 17 ноября 2009

Есть ли разница между двумя кодами ниже, я полагаю, нет.

function Agent(bIsSecret)
{
    if(bIsSecret)
        this.isSecret=true;

    this.isActive = true;
    this.isMale = false;
}

и

function Agent(bIsSecret)
{
    if(bIsSecret)
        this.isSecret=true;
}

Agent.prototype.isActive = true;    
Agent.prototype.isMale = true;

Ответы [ 4 ]

2 голосов
/ 17 ноября 2009

Существует разница, по крайней мере, если вы назначаете непримитивный объект для this.somevar или prototype.somevar.

Попробуйте запустить это:

function Agent(bIsSecret)
{
    if(bIsSecret)
        this.isSecret=true;

    this.isActive = true;
    this.isMale = false;
    this.myArray = new Array(1,2,3);
}

function Agent2(bIsSecret)
{
    if(bIsSecret)
        this.isSecret = true;
}

Agent2.prototype.isActive = true;    
Agent2.prototype.isMale = true;
Agent2.prototype.myArray = new Array(1,2,3);

var agent_a = new Agent();
var agent_b = new Agent();

var agent2_a = new Agent2();
var agent2_b = new Agent2();

if (agent_a.myArray == agent_b.myArray) 
    alert('agent_a.myArray == agent_b.myArray');
else
    alert('agent_a.myArray != agent_b.myArray');

if (agent2_a.myArray == agent2_b.myArray) 
    alert('agent2_a.myArray == agent2_b.myArray');
else
    alert('agent2_a.myArray != agent2_b.myArray');
1 голос
/ 17 ноября 2009

Нет. «прототип», используемый для реализации наследования в Javascript. Например:

/** obsolete syntax **/

var Person = Class.create();
Person.prototype = {
  initialize: function(name) {
    this.name = name;
  },
  say: function(message) {
    return this.name + ': ' + message;
  }
};

var guy = new Person('Miro');
guy.say('hi');
// -> "Miro: hi"

var Pirate = Class.create();
// inherit from Person class:
Pirate.prototype = Object.extend(new Person(), {
  // redefine the speak method
  say: function(message) {
    return this.name + ': ' + message + ', yarr!';
  }
});

var john = new Pirate('Long John');
john.say('ahoy matey');
// -> "Long John: ahoy matey, yarr!"

исходный код и дополнительную информацию вы можете найти здесь: http://www.prototypejs.org/learn/class-inheritance

0 голосов
/ 17 ноября 2009

Предполагая, что эта функция будет использоваться в качестве конструктора, первая с заданными свойствами в новом экземпляре, а вторая в прототипе. Если они не зависят от экземпляра, эти два фрагмента эквивалентны, но если они не являются (как следует из их названия), то это не так.

0 голосов
/ 17 ноября 2009

Функционально это то же самое. Последнее, однако, подчеркивает сходство между Agent объектами. Вы можете увидеть, что эти члены имеют это значение, в то время как в более сложной функции конструктора, с большим количеством условий, сложнее.

Это также позволяет среде выполнения javascript выбирать, как она будет обрабатывать Agent инициализации членов. (сделать некоторую прекомпиляцию, ...)

...