JavaScript 对象成员的可见性说明
作者:bea
JavaScript对象构造的可见性定义可以分为以下几种: 1,私有属性(private properties) 通过var关键字定义对象构造中变量的作用域,该变量只能在对象构造方法的作用域内被访问。如: 代码如下: function VariableTest() { var myVariable;//private } var vt = new VariableTest(); vt.myVariable;//这里会出现undefined异常
JavaScript对象构造的可见性定义可以分为以下几种:
1,私有属性(private properties)
通过var关键字定义对象构造中变量的作用域,该变量只能在对象构造方法的作用域内被访问。如:
代码如下:
function VariableTest()
{
var myVariable;//private
}
var vt = new VariableTest();
vt.myVariable;//这里会出现undefined异常
2,私有方法(private methods)
与私有属性类似,只能在对象构造方法作用域内被访问。如:
代码如下:
function MethodTest()
{
var myMethod = function()//private
{
alert("private method");
}
this.invoke = function()
{
//能够访问到myMethod
myMehtod();
}
}
var mt = new MethodTest();
mt.myMethod();//错误。使用trycatch的话,可捕获“对象不支持此属性或方法”异常
mt.invoke();
3,公共属性(public properties)
有两种定义公共属性的途径:
(1)通过this关键字来定义。如:
代码如下:
function PrivilegedVariable()
{
this.variable = "privileged variable";
}
var pv = new PrivilegedVariable();
pv.variable;//返回 "privileged variable"
(2)通过构造方法的原型来定义。如:
代码如下:
function PublicVariable(){}
PublicVariable.prototype.variable = "public variable";
var pv = new PublicVariable();
pv.variable;//返回"public variable"
4,公共方法(public methods)
同理,有两种定义公共方法的途径。
(1)通过this关键字来定义。(2)通过构造方法的原型来定义。
这里省略。。。。。。。。。。。
5,静态属性(static properties)
直接为对象构造方法添加的属性,不能被对象实例访问,只能供构造方法自身使用。如:
代码如下:
function StaticVariable(){}
StaticVariable.variable = "static variable";
var sv = new StaticVariable();
sv.variable;//返回"undefined"
StaticVariable.prototype.variable;//返回"undefined"
StaticVariable.variable;//返回"static variable"
6,静态方法(static methods)
直接为对象构造方法添加的方法,不能被对象实例访问,只能供构造方法自身使用。
代码省略。。。。。。。。
有用 | 无用
1,私有属性(private properties)
通过var关键字定义对象构造中变量的作用域,该变量只能在对象构造方法的作用域内被访问。如:
代码如下:
function VariableTest()
{
var myVariable;//private
}
var vt = new VariableTest();
vt.myVariable;//这里会出现undefined异常
2,私有方法(private methods)
与私有属性类似,只能在对象构造方法作用域内被访问。如:
代码如下:
function MethodTest()
{
var myMethod = function()//private
{
alert("private method");
}
this.invoke = function()
{
//能够访问到myMethod
myMehtod();
}
}
var mt = new MethodTest();
mt.myMethod();//错误。使用trycatch的话,可捕获“对象不支持此属性或方法”异常
mt.invoke();
3,公共属性(public properties)
有两种定义公共属性的途径:
(1)通过this关键字来定义。如:
代码如下:
function PrivilegedVariable()
{
this.variable = "privileged variable";
}
var pv = new PrivilegedVariable();
pv.variable;//返回 "privileged variable"
(2)通过构造方法的原型来定义。如:
代码如下:
function PublicVariable(){}
PublicVariable.prototype.variable = "public variable";
var pv = new PublicVariable();
pv.variable;//返回"public variable"
4,公共方法(public methods)
同理,有两种定义公共方法的途径。
(1)通过this关键字来定义。(2)通过构造方法的原型来定义。
这里省略。。。。。。。。。。。
5,静态属性(static properties)
直接为对象构造方法添加的属性,不能被对象实例访问,只能供构造方法自身使用。如:
代码如下:
function StaticVariable(){}
StaticVariable.variable = "static variable";
var sv = new StaticVariable();
sv.variable;//返回"undefined"
StaticVariable.prototype.variable;//返回"undefined"
StaticVariable.variable;//返回"static variable"
6,静态方法(static methods)
直接为对象构造方法添加的方法,不能被对象实例访问,只能供构造方法自身使用。
代码省略。。。。。。。。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- javascript 模拟Marquee文字向左均匀滚动代码
- 图片与文字半透明效果 鼠标移上不透明
- JavaScript 复制功能代码 兼容多浏览器
- 图片与JavaScript配合做出个性滚动条
- 简单的加密css地址防止别人下载你的CSS文件的方法
- 图片友情链接滚动 横向,带控制按钮
- javascript 定时自动切换的选项卡Tab
- JS 仿Flash动画放大/缩小容器
- document.onreadystatechange事件的用法分析
- 将jQuery应用于login页面的问题及解决
- 层序遍历在ExtJs的TreePanel中的应用
- JavaScript 基于原型的对象(创建、调用)
- JavaScript 定义function的三种方式小结
- JavaScript 函数式编程的原理
- 实现JavaScript中继承的三种方式
- 显示js对象所有属性和方法的函数
- 半角全角相互转换的js函数
- JavaScript 三种创建对象的方法
- JQuery困惑—包装集 DOM节点