- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
请仅针对 Javascript 提供您的想法!我知道类和经典继承,但不是很详细。
据我所知,构造函数被用作其他对象的原型(prototype)。例如,我可以创建一个汽车构造函数并为其提供 hondaCivic、toyotaCamry 等对象。关于构造函数还有其他重要的事情我应该了解吗?
此外,
最佳答案
构造函数只是一个普通函数。它本身并没有什么特别之处。
所有函数都有一个名为prototype
的属性。
如果你写
var myInstance = new MyFuction();
JavaScript 在执行函数时会对您的函数做一些特殊的事情。
它将函数体内的this
的值设置为myInstance
。此外,它还创建了对 MyFunction.prototype
的引用,并将其存储为 myInstance
的内部属性。
当您的代码正在执行时,解释器遵循的规则是,如果您尝试访问它找不到的 myInstance
上的属性,它将遵循对该函数的引用prototype
然后看那里。这形成了一条链,称为原型(prototype)链,一直通向 Object.prototype
。
这是一个例子:
function Dog(name, breed) {
this.name = name;
this.breed = breed;
//if you don't specify a return value, `this` will be returned
}
Dog.prototype.speak = function() {
alert('Ruff, I\'m ' + this.name + ' the talking ' + this.breed);
}
var myDog = new Dog('buttercup', 'poodle');
myDog.speak();
上面的代码片段有效,但如果您运行:console.log(myDog)
,您会发现它没有 speak 方法。 speak 方法是在它的原型(prototype)中找到的。
这意味着创建的 Dog
的所有“实例”都将共享相同的 speak
方法。
所以,如果我创造另一只狗,它也会说话:
var tommysDog = new Dog('rosco', 'pitbull');
tommysDog.speak(); //tommy's dog can speak too
function Dog(name, breed) {
this.name = name;
this.breed = breed;
//if you don't specify a return value, `this` will be returned
}
Dog.prototype.speak = function() {
alert('Ruff, I\'m ' + this.name + ' the talking ' + this.breed);
}
var myDog = new Dog('buttercup', 'poodle');
var tommysDog = new Dog('rosco', 'pitbull');
tommysDog.speak();
这也意味着如果我在运行时更改 Dog.prototype.speak
的值,所有实例都会受到影响。
注意:从技术上讲,函数确实有一个 constructor
属性,但它不是那么重要的,如果我试图这样做,它只会让你更加困惑在这里解释一下。
我建议您阅读 mozilla docs
此外,我建议您阅读 this book .你会学到很多关于正确设计的知识。
另请注意,这只是实现代码重用的一种方法。您根本不必通过原型(prototype)。事实上,JavaScript 有一些方法可以让您将任意值作为 this
的值提供给函数作为参数。
这意味着,即使我的宠物蜥蜴不能正常说话,我也可以通过使用类似call()
的方法从Dog.prototype
中借用方法。或 apply()
. (所有函数都有这些方法,因为它们从 Function.prototype
“继承”它们。)
function Dog(name, breed) {
this.name = name;
this.breed = breed;
//if you don't specify a return value, `this` will be returned
}
Dog.prototype.speak = function() {
alert('Ruff, I\'m ' + this.name + ' the talking ' + this.breed);
};
function Lizard(name, species) {
this.name = name;
this.species = species;
}
Lizard.prototype.speak = function() {
var pretend_dog = { name: this.name, breed: this.species };
Dog.prototype.speak.call(pretend_dog);
};
var myLizard = new Lizard('larry', 'chamelion');
myLizard.speak();
关于javascript - Javascript 构造函数有什么意义?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31630409/
我有一张 table People (First_Name, Last_Name)。此表包含与示例中一样重复的记录(并非所有行都重复): First_Name Last_Name John
我用 Java 编写过很多程序,之前也涉足过 C++。我在各种 C++ 书籍中阅读了有关指针的内容,并完成了书籍中的各种示例。 我了解指针的基础知识,但有一件事我一直不清楚。指针在现实世界中的应用是什
线 .Mappings(m => m.FluentMappings.AddFromAssemblyOf() 它有什么作用?它会在派生自 ClassMap 的 Product 类的程序集中查找任
我有用于打印数字的自定义打印功能。我制作了一个 ASCII 版本和一个 UTF-16LE 版本。 UTF-16LE 版本对 0-9 使用全角代码/字符,对十六进制使用 A-F。在调试我的函数时,我注意
这是我的代码片段: float ab(float); 以后 if(ab(temp)
我在一个项目文件中包含以下代码: //begin of the file ((window) => { 'use strict'; class View extends GSM.Event
我一直在到处寻找关于 ? 用法的正确解释。和 *。我注意到我可以使用以下方法拒绝所有用户的访问: 如果我想允许某个组,我应该在其上方添加下一行: 但是当我看到人们使用 ? 时,我开始忘记什么意思,
我正在关注 melon js tutorial .这是在我的 HUD.js 文件的顶部。 game.HUD = game.HUD || {} 我以前在其他例子中见过这个。 namespace.some
我正在处理一个包含数千行代码的文件。我正在第 700 行实现一个算法。我经常不得不离开这些行来检查文件中的其他方法。 导航回到我实际编码的地方通常很痛苦。如果我可以在第 700 行设置一个航路点并为其
我遇到了这段代码 do { if (higherQuality && w > targetWidth) { w /= 2; if (w &
uint8_t * const LCDMem = (uint8_t *) &LCDM3; 此代码在 msp430fg4618 培训套件中用于 lcd 配置。谁能解释一下上述代码的含义? 它允许使用 a
上下文 阅读一些内核代码。 问题 我不明白这行是什么意思 *(void **) &(int[2]){0,PAGE_SIZE}; 还有更多,这是什么意思 {0,PAGE_SIZE} 对我来说,它看起来不
我正在查看 Underscore.js 的源代码库,专门用于 map方法(该页面第 85 行左右,并复制到此处): _.map = function(obj, iterator, context)
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
我是一名优秀的程序员,十分优秀!