javascript原型链与特权方法
2015-06-22 09:19
459 查看
function ClassA() { var value=4; this.getValue= function() { return value; } this.setValue= function(value) { this.value=value; } } var instance= new ClassA(); document.write(instance.getValue()); classA.setValue(1); document.write(instance.getValue()); document.write(instance.value);
输出结果为:4,4,1。
原因是:var value 是私有变量,它与this.value不是同一个值。
下面我们分析下对象实例的创建与私有变量如何访问。
1.实例属性与原型属性
javascript对象创建实例时,实例属性和方法只有通过构造函数中的this,才可以赋给实例。如果想创建共享的属性或者方法,那么可以通过原型链共享。创建共享的属性:
function ClassA() { var value=4; this.getValue= function() { return value; } this.setValue= function(value) { this.value=value; } } ClassA.prototype.value=1;//共享的value var instance1=new ClassA(),// instance2=new ClassA(); consloe.log(instance1.value);//1 consloe.log(instance2.value);//1 console.log(ClassA.value);//undefined
那么ClassA()中的私有属性value我们可以通过ClassA.value访问吗?答案是不能。
我们分析下对象实例中标识符的查找。实例查找一个属性时,分为两步:
(1).在实例本身的实例属性中查找。
(2).如果查找不到实例属性,那么顺着原型链会找到对象的原型。
ClassA.value 在ClassA的实例属性中查找不到,那么继续查找原型链,ClassA是Object的实例,因此会查找Object.prototype.value,显然值为undefined。
2.私有变量的访问
我们知道,javascript没有块级作用域,但是我们可以通过函数来模拟块级作用域。而块级作用域里面的变量,称为私有变量。私有变量,外部无法访问,我们可以在函数内部生成特权方法(特权方法:能够访问私有变量的方法),这里的特权方法就是this.getValue();通过构造函数创建,是创建特权方法的一种方法。
创建特权方法的另外一种方式就是:静态方法。
function ClassA() { var value=4; this.getValue= function() { return value; } this.setValue= function(value) { this.value=value; } ClassA.getValue=function(){ //静态方法 return value; } }
相关文章推荐
- GoJS使用
- 通过JSON文件获取图片URL,下载并显示在布局中
- [资料搜集狂]D3.js数据可视化开发库
- javascript在页面head内动态插入style
- 浅谈javascript构造函数与实例化对象
- javascript中使用new与不使用实例化对象的区别
- JavaScript创建闭包的两种方式的优劣与区别分析
- js闭包所用的场合以及优缺点分析
- 浅谈js 闭包引起的内存泄露问题
- js window.localStorage 使用
- js
- JavaScript字符串函数大全
- 用js获取当前页面的url的相关信息方法
- 第一个JavaScript代码:JS
- 定时器的应用—JS学习笔记2015-6-21(第62天)
- JS 使用cloneChild 克隆元素节点
- JS使用removeChild 删除元素节点
- .Net——使用DataContractJsonSerializer进行序列化及反序列化基本操作
- .Net——使用DataContractJsonSerializer进行序列化及反序列化基本操作
- JS中冒号的作用