封装

面向对象语言的三大基本特种:
封装、继承和多态:
封装的操作毋庸置疑,是我们在整个代码编写的时候的一个重点,如果不考虑这些,代码的质量无法保障,而且后期维护也将变得极其麻烦。

下面是我对封装的理解的代码片段一:
(function(){
    var bar = 'World!'
    function baz(){
        return bar;
    }
    function foo(){
        return bar;
    }
    window.baz = baz; //Assign 'baz' to the global variable 'baz'...
})();
console.log(baz()); //...and now this works.
console.log(foo()); //... do not works.
/**
 * 上面的代码运行结果,foo()之所以不执行是因为foo()的作用域限制,
 * 而baz()因为赋值作为window的属性而暴露在匿名函数之外,
 * 这样即可以保持foo()函数的私有特性,又可以对外提供接口.
 */
下面是我对封装的理解的代码片段二:
(function(){
    var hello = "hello";
    var obj = {
        name:"iwen",
        getName:function(){
            console.log(this.name);
        }
    };
    (function(){
        console.log(hello);
    })();
    function myDemo(){
        obj.getName();
    }
    window.myDemo = myDemo;
})();
myDemo();

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注