- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用以下 ES2015 (ES6) 类定义:
class Card {
constructor(val) {
this.val = val;
}
val(){
return this.val;
}
}
(或等效的 ES5 和更早的代码)
但是,执行以下方法调用:
new Card(val).val()
抛出 TypeError: Card.val 不是函数
Card.x.call(Card)
似乎有同样的问题。
鉴于这两个名称应该保持不变,我如何才能正确引用原型(prototype)的 val
方法而不是对象的 val
字段?
最佳答案
I'm just trying to get inspiration of how we can effectively avoid such conflict in javascript, assuming that we have to name them in this way.
为避免混淆,我们将其称为 val
你有原型(prototype)“proto val
”和你在构造函数中分配的原型(prototype)“instance val
”。
对象(“实例 val
”)的属性不能与其原型(prototype)(“proto val
”)的属性同名,并且不能通过对象引用直接访问它们,根据上下文获取一个或另一个。这不是 JavaScript 所具有的功能。这是 JavaScript 属性查找工作方式所固有的,事实上 JavaScript 的“方法”只是引用函数的属性。
下面的选项,但让我们更仔细地看看为什么“instance val
”会覆盖“proto val
”:
对于上述代码的任一更正版本,此行:
var c = new Card(42);
在内存中给了我们这个(省略了一些细节):
+------------------------------------------+ | | \ +------------+ |Card>--+->| (function) | | +------------+ +-------------+ | | prototype |>---+->| (object) | | +------------+ / +-------------+ | | | constructor |>--+ +------------+ | | val |>----->| (function) | | +-------------+ +------------+ | +---------------+ |c>--->| (object) | | +---------------+ | | [[Prototype]] |>---+ | val: 42 | +---------------+
The identifier Card
(effectively a variable) refers to a function. That function's prototype
property refers to an object that we've put the "proto val
" method on. The variable c
refers to an instance which has what the spec calls an "internal slot" called [[Prototype]]
which refers to its prototype, which it got from Card.prototype
when we did new Card
. The prototype has a val
property pointing to the method, and also a constructor
property that points to back to the function Card
points to.
When we ask the JavaScript engine to look up the val
property on c
, it finds it on the object c
refers to, and uses it from there; the "instance val
" has overridden the "proto val
". If the "instance val
" weren't there, the JavaScript engine wouldn't find it on the object c
points to and would look to the object's prototype (what the object's [[Prototype]]
internal slot points to), and then it would find the val
property pointing to the function. But the "instance val
" is in the way.
You basically have three options:
Do what you've said you don't want to do: Give them different names. The data property ("instance val
") could be _val
for instance, or the method ("proto val
") could be getVal
(as method names should generally be verbs), or both (which would be quite common), etc.
Create the val
method in the constructor and don't have a val
data property at all:
// ES2015 (ES6) and higher
class Card {
constructor(val) {
this.val = function() {
return val;
};
}
}
或
// ES5 and earlier
function Card(val) {
this.val = function() {
return val;
};
}
自数据val
根本不再是实例的属性,与方法 val
没有冲突.
这是有效的,因为 val
方法现在是对 Card
调用上下文的闭包,因此它可以持久访问 val
争论。但是,没有原型(prototype)方法可以直接访问它;他们必须使用 this.val()
得到它。
做你现在正在做的事情,在原型(prototype)而不是实例上查找“proto val
”:
var c = new Card(val).val()
Object.getPrototypeOf(c).val.call(c); // ES5+
或(不太可靠)
var c = new Card(val).val()
Card.prototype.val.call(c);
或(更不可靠)
var c = new Card(val).val()
c.constructor.prototype.val.call(c);
...如您所见,这非常痛苦。它之所以有效,是因为在这些示例中我没有在 val
上查找“proto c
” (因为“实例val
”在路上);我直接在 c
的原型(prototype)上查找它(当然,在第一个示例中;可能在第二个示例中;希望在第三个示例中)。
关于javascript - 如何访问原型(prototype)上的阴影 JavaScript 对象字段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35451662/
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 4 年前。 Improv
PowerShell Web Access 允许您通过 Web 浏览器运行 PowerShell cmdlet。它显示了一个基于 Web 的控制台窗口。 有没有办法运行 cmdlet 而无需在控制台窗
我尝试在无需用户登录的情况下访问 Sharepoint 文件。 我可以通过以下任一方式获取访问 token 方法一: var client = new RestClient("https://logi
我目前正在尝试通过 Chrome 扩展程序访问 Google 服务。我的理解是,对于 JS 应用程序,Google 首选的身份验证机制是 OAuth。我的应用目前已成功通过 OAuth 向服务进行身份
假设我有纯抽象类 IHandler 和派生自它的类: class IHandler { public: virtual int process_input(char input) = 0; };
我有一个带有 ThymeLeaf 和 Dojo 的 Spring 应用程序,这给我带来了问题。当我从我的 HTML 文件中引用 CSS 文件时,它们在 Firebug 中显示为中止。但是,当我通过在地
这个问题已经有答案了: JavaScript property access: dot notation vs. brackets? (17 个回答) 已关闭 6 年前。 为什么这不起作用? func
我想将所有流量重定向到 https,只有 robot.txt 应该可以通过 http 访问。 是否可以为 robot.txt 文件创建异常(exception)? 我的 .htaccess 文件: R
我遇到了 LinkedIn OAuth2: "Unable to verify access token" 中描述的相同问题;但是,那里描述的解决方案并不能解决我的问题。 我能够成功请求访问 toke
问题 我有一个暴露给 *:8080 的 Docker 服务容器. 我无法通过 localhost:8080 访问容器. Chrome /curl无限期挂断。 但是如果我使用任何其他本地IP,我就可以访
我正在使用 Google 的 Oauth 2.0 来获取用户的 access_token,但我不知道如何将它与 imaplib 一起使用来访问收件箱。 最佳答案 下面是带有 oauth 2.0 的 I
我正在做 docker 入门指南:https://docs.docker.com/get-started/part3/#recap-and-cheat-sheet-optional docker-co
我正在尝试使用静态 IP 在 AKS 上创建一个 Web 应用程序,自然找到了一个带有 Nginx ingress controller in Azure's documentation 的解决方案。
这是我在名为 foo.js 的文件中的代码。 console.log('module.exports:', module.exports) console.log('module.id:', modu
我试图理解访问键。我读过https://docs.aws.amazon.com/general/latest/gr/aws-sec-cred-types.html#access-keys-and-se
我正在使用 MGTwitterEngine"将 twitter 集成到我的应用程序中。它在 iOS 4.2 上运行良好。当我尝试从任何 iOS 5 设备访问 twitter 时,我遇到了身份验证 to
我试图理解访问键。我读过https://docs.aws.amazon.com/general/latest/gr/aws-sec-cred-types.html#access-keys-and-se
我正在使用以下 API 列出我的 Facebook 好友。 https://graph.facebook.com/me/friends?access_token= ??? 我想知道访问 token 过
401 Unauthorized - Show headers - { "error": { "errors": [ { "domain": "global", "reas
我已经将我的 django 应用程序部署到 heroku 并使用 Amazon s3 存储桶存储静态文件,我发现从 s3 存储桶到 heroku 获取数据没有问题。但是,当我测试查看内容存储位置时,除
我是一名优秀的程序员,十分优秀!