首页 > web前端 > js教程 > 如何从 JavaScript 中的原型定义函数访问私有成员?

如何从 JavaScript 中的原型定义函数访问私有成员?

Patricia Arquette
发布: 2024-10-29 00:07:30
原创
941 人浏览过

How Can I Access Private Members from Prototype-Defined Functions in JavaScript?

从原型定义的函数中访问私有成员变量

在 JavaScript 中,当在类的构造函数中定义方法时,可以访问 private在构造函数中声明的变量。然而,在原型上定义方法时,访问这些私有变量就出现问题了。

举例说明:

<code class="js">function TestClass() {
    var privateField = "hello";
    this.nonProtoHello = function() { alert(privateField); };
}
TestClass.prototype.prototypeHello = function() { alert(privateField); };</code>
登录后复制

调用 t.nonProtoHello() 可以正确访问私有 privateField,但是 t.prototypeHello () 抛出错误。这是因为原型定义的方法不是在构造函数的作用域内定义的,因此无法访问其局部变量。

不幸的是,没有办法直接从原型定义的函数访问私有变量。但是,您可以使用 getter 和 setter 实现类似的功能。

<code class="js">function Person(name, secret) {
    // Public
    this.name = name;

    // Private
    var secret = secret;

    // Public methods have access to private members
    this.setSecret = function(s) {
        secret = s;
    }

    this.getSecret = function() {
        return secret;
    }
}

// Must use getters/setters 
Person.prototype.spillSecret = function() { alert(this.getSecret()); };</code>
登录后复制

在此示例中,原型定义的方法可以通过 getter 和 setter 函数访问私有变量 Secret。

以上是如何从 JavaScript 中的原型定义函数访问私有成员?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板