资讯专栏INFORMATION COLUMN

【JavaScript】通过闭包创建具有私有属性的实例对象

MingjunYang / 1513人阅读

摘要:静态私有变量私有属性特权方法模块模式模块模式是为单例创建私有变量和特权方法。单例是只有一个实例的对象。私有变量和函数初始化公共增强的模块模式这种模式专用于单例必须是某种类型的实例,同时还必须添加某些属性和方法对其加强的情况。

静态私有变量
(function(){
    //私有属性
    var name = "";
    Person = function(value) {
        name = value;
    };
    //特权方法
    Person.prototype.getName = function() {
        return name;
    };
    Person.prototype.setName = function(value) {
        name = value;
    };
})();
var person = new Person("hiyohoo");
console.log(person.getName()); //hiyohoo
person.setName("xujian");
console.log(person.getName()); //xujian
模块模式

模块模式是为单例创建私有变量和特权方法。单例是只有一个实例的对象。这种模式常用于对单例进行某种初始化,同时又需要维护其私有变量。

var student = function() {
    //私有变量和函数
    var students = new Array();
    //初始化
    students.push(new Person());
    //公共
    return {
        getStudentCount: function() {
            return students.length;
        },
        registerStudent: function(person) {
            if (person instanceof Person) {
                students.push(person);
            }
        }
    };
}();
增强的模块模式

这种模式专用于单例必须是某种类型的实例,同时还必须添加某些属性和方法对其加强的情况。在下面的例子中,student的值是匿名函数返回的stu,也就是Person的一个实例,这个实例有两个公共的方法,用于访问实例属性。

var student = function() {
    //私有变量和函数
    var students = new Array();
    //初始化
    students.push(new Person());
    //创建student的一个局部副本
    var stu = new Person;
    //公共接口
    stu.getStudentCount = function() {
        return students.length;
    };
    stu.registerStudent = function(preson) {
        if (person instanceof Person) {
            students.push(person);
        }
    };
    //返回这个副本
    return stu;
}(); 

转载请注明出处:https://segmentfault.com/a/1190000004590427

文章不定期更新完善,如果能对你有一点点启发,我将不胜荣幸。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/78885.html

相关文章

  • JavaScript】【函数】闭包闭包

    摘要:要想保存在循环过程中每一个的值,需要在匿名函数外部再套用一个匿名函数,在这个匿名函数中定义另一个变量并且立即执行来保存的值。这时最内部的匿名函数访问的是的值,所以数组中个匿名函数的返回值就是。才是匿名函数功能执行的环境。 闭包,有人说它是一种设计理念,有人说所有的函数都是闭包。我不知道如何去定义它,我也不准备去定义它,定义它就是限制了对它的理解。 我们依赖光来看清世间万物,光却遮住了黑...

    he_xd 评论0 收藏0
  • 封装

    摘要:上一篇文章距离有出不多一个多月了现在好不容易有了好心情继续看书写点感悟第三章讲述的是封装像可以通过关键字来声明一个方法使得只有该对象内部的代码才能执行它在中没有这样的关键字但是可以使用闭包来创建只允许从对象内部访问的方法和属性相比于闭包走了 上一篇文章距离有出不多一个多月了,现在好不容易有了好心情,继续看书,写点感悟. 第三章讲述的是js封装,像java,可以通过private关键字来...

    Ethan815 评论0 收藏0
  • JavaScript 闭包

    摘要:闭包的注意事项通常,函数的作用域及其所有变量都会在函数执行结束后被销毁。但是,在创建了一个闭包以后,这个函数的作用域就会一直保存到闭包不存在为止。最后通过释放了和对闭包的引用。从而使用闭包模块化代码,减少全局变量的污染。 JavaScript 闭包 原文链接 什么是闭包(Closure) 简单讲,闭包就是指有权访问另一个函数作用域中的变量的函数。 MDN 上面这么说:闭包是一种特殊的...

    zhou_you 评论0 收藏0
  • JavaScript高级程序设计》(第3版)读书笔记 第7章 函数表达式

    摘要:定义函数表达式的方式有两种函数声明。不过,这并不是匿名函数唯一的用途。可以使用命名函数表达式来达成相同的结果闭包匿名函数和闭包是两个概念,容易混淆。匿名函数的执行环境具有全局性,因此其对象通常指向通过改变函数的执行环境的情况除外。 定义函数表达式的方式有两种: 函数声明。它的重要特征就是 函数声明提升(function declaration hoisting) 即在执行代码之前会...

    邹立鹏 评论0 收藏0
  • javascript中关于作用域和闭包

    摘要:在代码执行时,对应的作用域链常常是保持静态的。当语句执行完毕后,会把作用域链恢复到原始状态。在全局作用域中创建的函数,其作用域链会自动成为全局作用域中的一员。 列表项目 前言 学习了javascript已经很久了,关于这个语言中的这两个特性也是早已耳熟能详,但是在实际的使用的过程中或者是遇到相关的问题的时候,还是不能很好的解决。因此我觉得很有必要深入的学习并且记录这个问题,以便在今后的...

    zacklee 评论0 收藏0

发表评论

0条评论

MingjunYang

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<