对象封装:
var Cat = {
createNew: function(){
var cat = {};
cat.name = "大毛";
cat.makeSound = function(){ alert("喵喵喵"); };
return cat;
}
};
调用:
var cat1 = Cat.createNew();
alert(cat1.sound); // undefined
数据共享:
var Cat = {
sound : "喵喵喵",
createNew: function(){
var cat = {};
cat.makeSound = function(){ alert(Cat.sound); };
cat.changeSound = function(x){ Cat.sound = x; };
return cat;
}
};
2个实例:
var cat1 = Cat.createNew();
var cat2 = Cat.createNew();
cat1.makeSound(); // 喵喵喵
一个实例对象,修改了共享的数据,另一个实例对象也会受到影响。
cat2.changeSound("啦啦啦");
cat1.makeSound(); // 啦啦啦
私有:
var Cat = {
createNew: function(){
var cat = {};
var sound = "喵喵喵";
cat.makeSound = function(){ alert(sound); };
return cat;
}
};
外部无法读取,只有通过cat的公有方法makeSound()来读取。
var cat1 = Cat.createNew();
alert(cat1.sound); // undefined
本文探讨了JavaScript中对象封装的概念及其在代码组织和数据保护中的作用。通过对比不同封装方式下数据共享的影响,展示了如何在不泄露内部状态的情况下实现功能复用。进一步分析了私有属性的实现,强调了封装对于提高代码质量和维护性的关键性。最后,通过实例演示了如何在类中使用私有属性和共享属性,并讨论了它们之间的区别和适用场景。

被折叠的 条评论
为什么被折叠?



