JavaScript 私有成员分析


Posted in Javascript onJanuary 13, 2009

对象
JavaScript操作都是关于对象的。数组(Array)是对象,函数(Function)是对象。Object(类型)是对象。那么什么是对象呢?对象就是“名称-值”对(name-value)。名称是字符串,值可以是字符串、数值、布尔值或对象(包括数组和函数)。对象经常用哈希表实现,所以取值速度很快。
如果对象的一个值是函数(function),我们可以认为它是成员函数,当成员函数被调用时,this变量就会指向该对象。成员函数可以通过this变量访问对象的成员。
对象可以通过构造器(constructor)生成,构造器是个初始化对象的函数。构造器在这里扮演了其他语言中“类”扮演的角色,也提供了定义static变量和方法的手段。
Public成员
对象的所有成员都是公开成员,谁都可以读写甚至删除这些成员或添加新成员。添加新成员有两种方法:
在构造器里添加
这通常被用来初始化公开的成员变量。利用构造器的this变量来把成员添加到对象里。
function Container(param)
{ this.member = param;}
用下面这行代码生成一个对象实例
var myContainer = new Container('abc');
myContainer的member成员值为'abc'。
在原型中添加
这种方法经常用来添加公开成员函数。当Javascrīpt解释器遇到一个对象的成员,发现对象自身中并不存在这个成员时,就会到对象构造函数 的原型中去找。原型机制可以用来实现继承。它同样占用内存。如果想要给某个构造函数生成的所有对象都添加一个方 法,只要给对象的原型添加这个方法就可以了。
Container.prototype.stamp = function (string) { return this.member + string;}
这样就可以调用这个成员函数
myContainer.stamp('def')
返回值'abcdef'。
私有成员
私有成员是在构造器里产生的。var定义的变量和构造器的参数会成为私有成员。
function Container(param){
this.member = param;
var secret = 3;
var that = this;
}
这个构造器定义了三个私有变量:param,secret和self。它们属性对象Container,而对象外的代码或是对象的公开方法都无法访问它们。
只有私有方法可以访问。私有方法是构造器内定义的函数。
function Container(param){
function dec() {
if (secret > 0)
{ secret -= 1; return true; }
else {
return false;
} }
this.member = param;
var secret = 3;
var that = this;}
私有方法 dec 检查实例变量 secret 的值,如果它大于0就减少它的值然后返回true;否则它返回false。
它可以用于限制这个对象只能被使用3次。
根据协议,我们定义了一个私有变量that,用来让私有方法可以访问对象本身。
这是一个变通的解决方案,需要它的根本原因在于ECMAscrīpt语言规范的一个错误,而这个错误导致内部函数的this变量有
错误。(honker:似乎不用that也没关系,也许是原文写得太早了,哪位高人遇到过这种问题?)
私有方法不能被公开方法调用。为了让私有函数有用,我们需要引入特权方法的概念。
特权
特权方法可以访问私有变量和方法,并且它本身可以被公开方法和外部访问。可以删除或替换一个特权方法但是不能改变它或强迫它放弃自己的秘密。
特权方法是在构造函数通过this定义的
function Container(param) {
function dec() {
if (secret > 0) {
secret -= 1;
return true;
} else {
return false;
} }
this.member = param;
var secret = 3;
var that = this;
this.service = function () {
if (dec()) {
return that.member;
} else {
return null;
} };}
service是一个特权方法。前三次调用myContainer.service()将返回'abc',之后它将返回null。service调用私有的dec方法,dec方法访问私有的secret变量。service对其他对象和函数都是可见的,但我们不能直接访问private成员。
闭包
因为有了闭包的我,这些公开、私有和特权方法的写法才成为可能。它意味着内部函数总能访问它外层函数定义的变量和参数。即使外层函数已经返回。这是Javascrīpt的一个极其强大的特性。目前还没有如何一本Javascrīpt编程的书讲到如何利用它,大多都没有提到它。
私有和特权成员只能在对象被构造时生成。公开成员可以在任何时间添加。
写法
Public
function Constructor(...) {
this.membername = value;
}
Constructor.prototype.membername = value;
Private
function Constructor(...) {
var that = this;
var membername = value;
function membername(...) {...}
}
Note: The function statement
function membername(...) {...}
is shorthand for
var membername = function membername(...) {...};
Privileged
function Constructor(...) {
this.membername = function (...) {...};
}

Javascript 相关文章推荐
javascript getElementsByClassName函数
Apr 01 Javascript
Javascript创建自定义对象 创建Object实例添加属性和方法
Jun 04 Javascript
js解析与序列化json数据(二)序列化探讨
Feb 01 Javascript
jquery实现可拖动DIV自定义保存到数据的实例
Nov 20 Javascript
Javascript对象属性方法汇总
Nov 21 Javascript
jQuery左侧大图右侧小图焦点图幻灯切换代码分享
Aug 19 Javascript
javascript运动效果实例总结(放大缩小、滑动淡入、滚动)
Jan 08 Javascript
jQuery焦点图轮播插件KinSlideshow用法分析
Jun 08 Javascript
JS+canvas实现的五子棋游戏【人机大战版】
Jul 19 Javascript
vue项目中锚点定位替代方式
Nov 13 Javascript
vue 子组件修改data或调用操作
Aug 07 Javascript
js中延迟加载和预加载的具体使用
Jan 14 Javascript
js利用Array.splice实现Array的insert/remove
Jan 13 #Javascript
JavaScript delete操作符应用实例
Jan 13 #Javascript
在网页里看flash的trace数据的js类
Jan 10 #Javascript
捕获关闭窗口的脚本
Jan 10 #Javascript
javascript 自动转到命名锚记
Jan 10 #Javascript
Javascript 生成指定范围数值随机数
Jan 09 #Javascript
Js 订制自己的AlertBox(信息提示框)
Jan 09 #Javascript
You might like
如何给phpcms v9增加类似于phpcms 2008中的关键词表
2013/07/01 PHP
PHP递归创建多级目录
2015/11/05 PHP
PHP通过curl获取接口URL的数据方法
2018/05/31 PHP
Laravel 6 将新增为指定队列任务设置中间件的功能
2019/08/06 PHP
JavaScript Event学习第三章 早期的事件处理程序
2010/02/07 Javascript
自定义jQuery选项卡插件实例
2013/03/27 Javascript
文本框只能选择数据到文本框禁止手动输入
2013/11/22 Javascript
js或jquery实现页面打印可局部打印
2014/03/27 Javascript
js使用ajax读博客rss示例
2014/05/06 Javascript
javascript中bind函数的作用实例介绍
2014/09/28 Javascript
JavaScript的面向对象编程基础
2015/08/13 Javascript
JavaScript的ExtJS框架中表格的编写教程
2016/05/21 Javascript
基于 Vue 的树形选择组件的示例代码
2017/08/18 Javascript
解析vue data不可以使用箭头函数问题
2018/07/03 Javascript
vue+element实现表单校验功能
2019/05/20 Javascript
浅谈layui使用模板引擎动态渲染元素要注意的问题
2019/09/14 Javascript
js实现扫雷源代码
2020/11/27 Javascript
[02:36]DOTA2混沌骑士 英雄基础教程
2013/11/26 DOTA
python解决字典中的值是列表问题的方法
2013/03/04 Python
使用python在校内发人人网状态(人人网看状态)
2014/02/19 Python
Python中使用select模块实现非阻塞的IO
2015/02/03 Python
Python实现将Excel转换为json的方法示例
2017/08/05 Python
Python3实现的旋转矩阵图像算法示例
2019/04/03 Python
PyCharm 无法 import pandas 程序卡住的解决方式
2020/03/09 Python
python实现逢七拍腿小游戏的思路详解
2020/05/26 Python
如何在VSCode下使用Jupyter的教程详解
2020/07/13 Python
Python自动化测试中yaml文件读取操作
2020/08/20 Python
Python爬虫之Selenium实现窗口截图
2020/12/04 Python
简单几步用纯CSS3实现3D翻转效果
2019/01/17 HTML / CSS
单身旅行者的单身假期:Just You
2018/04/08 全球购物
介绍一下游标
2012/01/10 面试题
环境工程专业毕业生求职信
2014/09/30 职场文书
教师节作文之小学四年级
2019/09/03 职场文书
MySQL 时间类型的选择
2021/06/05 MySQL
Python anaconda安装库命令详解
2021/10/16 Python
SQL Server中锁的用法
2022/05/20 SQL Server