- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
当我有我想用作构造函数的函数时,请说:
function clog(x){
var text = x;
return console.log(text );
}
var bla = new clog();
clog.prototype.alert = alert(text);
clog.alert = alert(text);
clog
的对象继承吗?是他们的原型(prototype)吗?
最佳答案
由构造函数创建的实例(在您的情况下为 clog
)继承对 clog.prototype
的引用。目的。因此,如果您将属性添加到 clog.prototype
,它将显示在实例上。如果您向 clog
添加属性本身,它不会出现在实例上。
您引用的代码存在一些问题,因此让我们看一个抽象示例:
function Foo() {
}
Foo.prototype.bar = "I'm bar on Foo.prototype";
Foo.bar = "I'm bar on Foo";
var f = new Foo();
console.log(f.bar); // "I'm bar on Foo.prototype"
// E.g., `f` inherits from `Foo.prototype`, not `Foo`
// And this link is live, so:
Foo.prototype.charlie = "I'm charlie on Foo.prototype";
console.log(f.charlie); // "I'm charlie on Foo.prototype";
I don't understand why new properties added directly to
Foo
would be ignored by the prototype chain?
Foo.prototype
,不是
Foo
,这是通过
new Foo()
创建的对象的原型(prototype).
isn't
prototype
simply points to the constructor object?
Foo
和
Foo.prototype
是完全不同的对象。
Foo
是一个函数对象,它像所有函数对象一样可以有属性。
Foo
之一的属性是
prototype
,这是一个非函数对象,除了
constructor
之外最初是空白的指向
Foo
的属性.它是
Foo.prototype
,不是
Foo
,通过
new Foo
创建的实例得到他们的原型(prototype)。
Foo
的唯一作用是创建使用
Foo.prototype
的对象。作为他们的原型(prototype)。 (实际上,在
Foo
的情况下,它只是初始化这些对象;它们由
new
运算符创建。使用像
Foo
这样的传统函数,
new
创建对象。如果此代码使用 ES2015+
class
语法,
new
不会创建对象,它将留给
Foo
[如果
Foo
是基类构造函数] 或
Foo
的最终基类 [如果
Foo
子类构造函数]。)
If I do
Foo.newProp = "new addition"
why isf.newProp => undefined
?
Foo.new = ...
更改为
Foo.newProp = ...
,因为
new
是一个关键字。虽然您可以像在 ES5 中那样使用它,但最好不要这样做。)
Foo.newProp
与
f
几乎没有任何关系.您可以在
f.constructor.newProp
上找到它, 自
f.constructor
是
Foo
.
function Foo() {
}
Foo.prototype.bar = "I'm bar on Foo.prototype";
Foo.bar = "I'm bar on Foo";
+−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−+ | | V +−−−−−−−−−−−−−−−−−−+ |+−−−−−−−−−−−−−−−−+ +−−>| [String] | || Foo [Function] | | +−−−−−−−−−−−−−−−−−−+ |+−−−−−−−−−−−−−−−−+ | | "I'm bar on Foo" | || bar |−−−−+ +−−−−−−−−−−−−−−−−−−+ || prototype |−−−−+ |+−−−−−−−−−−−−−−−−+ | | +−−−−−−−−−−+ | | | V | +−−−−−−−−−−−−−+ | | [Object] | | +−−−−−−−−−−−−−+ | | constructor |−−+ +−−−−−−−−−−−−−−−−−−−−−−−−−−−−+ | bar |−−−−−>| [String] | +−−−−−−−−−−−−−+ +−−−−−−−−−−−−−−−−−−−−−−−−−−−−+ | "I'm bar on Foo.prototype" | +−−−−−−−−−−−−−−−−−−−−−−−−−−−−+
Now if we do
var f = new Foo();
+−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−+ | | V +−−−−−−−−−−−−−−−−−−+ |+−−−−−−−−−−−−−−−−+ +−−>| [String] | || Foo [Function] | | +−−−−−−−−−−−−−−−−−−+ |+−−−−−−−−−−−−−−−−+ | | "I'm bar on Foo" | || bar |−−−−+ +−−−−−−−−−−−−−−−−−−+ || prototype |−−−−+ |+−−−−−−−−−−−−−−−−+ | | +−−−−−−−−−−−−−+ | | | V |+−−−−−−−−−−−−−−−+ +−−−−−−−−−−−−−+ || f [Object] | +−−−−−>| [Object] | |+−−−−−−−−−−−−−−−+ | +−−−−−−−−−−−−−+ || [[Prototype]] |−−−−−−−−−−+ | constructor |−−+ +−−−−−−−−−−−−−−−−−−−−−−−−−−−−++−−−−−−−−−−−−−−−+ | bar |−−−−>| [String] | +−−−−−−−−−−−−−+ +−−−−−−−−−−−−−−−−−−−−−−−−−−−−+ | "I'm bar on Foo.prototype" | +−−−−−−−−−−−−−−−−−−−−−−−−−−−−+
([[Prototype]] is an object's internal field referring to its prototype. This is accessible via Object.getPrototypeOf
[or __proto__
on JavaScript engines on web browsers, but don't use __proto__
, it's just for backward compatibility with old SpiderMonkey-specific code.)
Now suppose we do this:
f.charlie = "I'm charlie on f";
f
对象(
粗体 中的新内容):
+−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−+ | | V +−−−−−−−−−−−−−−−−−−+ |+−−−−−−−−−−−−−−−−+ +−−>| [String] | || Foo [Function] | | +−−−−−−−−−−−−−−−−−−+ |+−−−−−−−−−−−−−−−−+ | | "I'm bar on Foo" | || bar |−−−−+ +−−−−−−−−−−−−−−−−−−+ || prototype |−−−−+ |+−−−−−−−−−−−−−−−−+ | | +−−−−−−−−−−−−−+ | | | V |+−−−−−−−−−−−−−−−+ +−−−−−−−−−−−−−+ || f [Object] | +−−−−−>| [Object] | |+−−−−−−−−−−−−−−−+ | +−−−−−−−−−−−−−+ || [[Prototype]] |−−−−−−−−−−+ | constructor |−−+ +−−−−−−−−−−−−−−−−−−−−−−−−−−−−+| charlie |−−−−−−−−−−+ | bar |−−−−−>| [String] |+−−−−−−−−−−−−−−−+ | +−−−−−−−−−−−−−+ +−−−−−−−−−−−−−−−−−−−−−−−−−−−−+ | | "I'm bar on Foo.prototype" | | +−−−−−−−−−−−−−−−−−−−−−−−−−−−−+ | | +−−−−−−−−−−−−−−−−−−−−+ +−−−−−>| [String] | +−−−−−−−−−−−−−−−−−−−−+ | "I'm charlie on f" | +−−−−−−−−−−−−−−−−−−−−+
f
now has its own property, called charlie
. This means that these two statements:
console.log(f.charlie); // "I'm charlie on f"
console.log(f.bar); // "I'm bar on Foo.prototype"
f.charlie
第一的。这是引擎如何处理
f.charlie
:
f
有自己的属性叫做 "charlie"
? f.bar
:
f
有自己的属性叫做 "bar"
? f
有原型(prototype)吗? f
的原型(prototype)有一个名为 "bar"
的属性? f.charlie
之间有很大的区别和
f.bar
:
f
有它的
自己的 名为
charlie
的属性,但是一个
继承名为
bar
的属性.如果
f
的原型(prototype)对象没有名为
bar
的属性,它的原型(prototype)对象(在这种情况下,
Object.prototype
)将被检查,依此类推,直到我们用完原型(prototype)。
hasOwnProperty
测试一个属性是否是“自己的”属性。所有对象都具有的功能:
console.log(f.hasOwnProperty("charlie")); // true
console.log(f.hasOwnProperty("bar")); // false
I make
function Person(first_name, last_name) {this.first_name = first_name; this.last_name = last_name;}
and thenvar ilya = new Person('ilya', 'D')
how does it resolves the innername
properties?
Person
这是
new Person(...)
的一部分表达式,
this
new
返回的新生成的对象表达。所以当你做
this.prop = "value";
,您直接在该对象上放置一个属性,与原型(prototype)无关。
p
目的:
// Example 1:
function Person(name) {
this.name = name;
}
var p = new Person("Fred");
// Example 2:
function Person() {
}
var p = new Person();
p.name = "Fred";
function clog(x){
var text = x;
return console.log(text ); // <=== here
}
new
操作工程是:
prototype
中获得了一个原型(prototype)。属性(property)。 this
指向新对象。 new
的结果expression 是在步骤 1 中创建的对象。new
操作是那个对象。 console.log
不返回任何内容,您只需删除
return
代码中的关键字。但是如果你使用了
return xyz();
用一个返回对象的函数构造,你会弄乱你的构造函数。
clog.prototype.alert = alert(text);
alert
函数并将其结果分配给名为
alert
的属性在
clog.prototype
.自
alert
不返回任何内容,它完全等同于:
alert(text);
clog.prototype.alert = undefined;
clog.prototype.alert = function(text) {
alert(text);
};
alert
原型(prototype)上的属性。当函数被调用时,它会调用标准
alert
.
new
的函数)应该以大写字母开头,所以
Clog
而不是
clog
.不过,这只是风格。
关于javascript - 向没有 .prototype 的构造函数添加新属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9582341/
谁能解释一下原因: (define a (lambda() (cons a #f))) (car (a)) ==> procedure ((car (a))) ==> (procedure . #f)
这是 PyBrain 网站的摘录。我了解大部分正在发生的事情,但是一行让我完全难住了。我以前从未在 python 代码中看到过这样的东西。这是整个循环,对于上下文: for c in [0,
我是gradle / groovy的新手。我想创建将做一些事情的自定义任务。我的第一个问题是任务完成时该如何做?我可以覆盖doFirst / doLast闭包吗?也许我可以重写某些在开始和结束时都会执
我刚刚开始评估 MS 企业库。他们使用以下指令来获取实例: var customerDb = EnterpriseLibraryContainer.Current.GetInstance("C
这是我的 if else Ansible 逻辑.. - name: Check certs exist stat: path=/etc/letsencrypt/live/{{ rootDomain
我正在使用construct 2.8 对一些失传已久的 Pascal 程序创建的一些文件的 header 进行逆向工程。 header 由许多不同的记录组成,其中一些是可选的,我不确定顺序是否固定。
我在将 getchar() 的输入放入 char *arr[] 数组时遇到问题。我这样做的原因是因为输入数据(将是一个带有命令行参数的文件)将存储在一个 char 指针数组中以传递给 execvp 函
通常我们不能约束类型参数 T派生自密封类型(例如 struct 类型)。这将毫无意义,因为只有一种类型适合,因此不需要泛型。所以约束如下: where T : string 或: where T :
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve th
#include using namespace std; class A { private: int m_i; friend int main(int argc, char cons
这个问题在这里已经有了答案: Are there legitimate uses for JavaScript's "with" statement? (33 个答案) 关闭 9 年前。 我有这个代
在this answer我看到了下一个 Bash 结构。 yes "$(< file.txt)" 什么意思 "$(< file.txt)" ? 我明白了 命令替换 - $(command)用命令的结
if (a == 1) //do something else if (a == 2) //do something else if (a == 3) //do somethi
关于构造的快速简单的问题。 我有以下用于将项目添加到 ListView 的代码。 ListViewItem item = new ListViewItem(); item.Text = file; i
我想使用 std::vector 来控制给定的内存。首先,我很确定这不是好的做法,但好奇心占了上风,无论如何我都想知道如何做到这一点。 我遇到的问题是这样的方法: vector getRow(unsi
下面显示了一段简单的javascript: var mystring = ("random","ignored","text","h") + ("ello world") 这个字符串会生成 hello
在 Java 中,创建对象的标准方法是使用 MyClass name = new MyClass(); 我也经常看到构造 new MyClass() { /*stuff goes in here*/
我正在编写 C++ ndarray 类。我需要动态大小和编译时大小已知的数组(分别分配自由存储和分配堆栈)。我想支持从嵌套的 std::initializer_list 进行初始化。 动态大小的没问题
我正在将一个项目从 Visual Studio 2005 转换为 Visual Studio 2008,并提出了上述结构。 using Castle.Core.Resource; using Cast
我想知道我在这里的想法是否正确,我主要针对接口(interface)进行编程,所以我想知道下面的类是否应该通过 DI 注入(inject),或者我应该自己实例化一个类... 注意:这些服务保存在我的核
我是一名优秀的程序员,十分优秀!