首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >原型Javascript设计方法

原型Javascript设计方法
EN

Code Review用户
提问于 2017-01-18 16:37:57
回答 1查看 30关注 0票数 -2

这种原型设计模式在功能上有什么不同吗?

代码语言:javascript
复制
var Greeter = function(message) {
    this.greeting = message;
    return this;
}

Greeter.prototype.greet = function () {
    return "Hellos, " + this.greeting;
}

相对于:

代码语言:javascript
复制
var Greeter = (function () {
    function Greeter(message) {
        this.greeting = message;
    }
    Greeter.prototype.greet = function () {
        return "Hellos, " + this.greeting;
    };
    return Greeter;
}());

底层的方法似乎更干净,所以我选择更频繁地使用它,但是我已经看到很多人使用顶级方法。

EN

回答 1

Code Review用户

发布于 2017-01-18 17:18:17

您将注意到,两个示例中的核心逻辑基本相同。因此,这里唯一的区别在于是否允许从全局范围调用函数(类)定义。

在第二个示例中,将逻辑封装在IIFE中具有将函数定义隐藏在全局范围之外的效果,实质上是提供单例行为。

您可能使用的内容可能取决于应用程序的需要。

票数 1
EN
页面原文内容由Code Review提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://codereview.stackexchange.com/questions/152955

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档