作者:zccst
一、[color=red]公有、静态、私有和特殊[/color] 属性/方法
1,在js对象中添加公有成员和公有方法
一种是使用this
另一种是使用prototype
2,在js对象中添加静态成员和静态方法
使用
3,在js对象中添加私有方法
4,特权方法this
与prototype的区别是this可以调用私有属性和私有成员
私有和特权在函数内部,他们会带到函数实例中,因而占用大量内存
公有原型成员是对象的一部分,适用于通过new。
静态成员只适用于对象的一个特殊实例。(原因是存在于对象之下)
二、字面量
var obj = {
key1:value1; //静态
key2:value2
}
function myContructor(){}与var mycontructor = function(){}区别
前者是全局,可以在定义之前调用。后面是一个变量,必须在定义之后才能使用。
三、call和apply
强行把this指到某个对象。解决由于环境不同导致this错乱。
call(object, arg1, arg2);
apply(object, argArray);
四、异常处理
一、[color=red]公有、静态、私有和特殊[/color] 属性/方法
1,在js对象中添加公有成员和公有方法
一种是使用this
另一种是使用prototype
2,在js对象中添加静态成员和静态方法
使用
obj.name = "";
obj.Display = function(){
}
3,在js对象中添加私有方法
function myConstructor(message){
this.myMessage = message;
//私有属性
var myOwner = this;
var separator = '_';
//私有方法
function alertMessage(){
alert(myOwner.message);
}
alertMessage();
}
4,特权方法this
与prototype的区别是this可以调用私有属性和私有成员
私有和特权在函数内部,他们会带到函数实例中,因而占用大量内存
公有原型成员是对象的一部分,适用于通过new。
静态成员只适用于对象的一个特殊实例。(原因是存在于对象之下)
二、字面量
var obj = {
key1:value1; //静态
key2:value2
}
function myContructor(){}与var mycontructor = function(){}区别
前者是全局,可以在定义之前调用。后面是一个变量,必须在定义之后才能使用。
function myConstructor(){}
myConstructor.prototype = {
propertyA : 'value',
propertyB : 'value',
methodA : function(){},
methodB : function(){} //如果加了逗号,表示未完,默认为空导致全部为空
}
三、call和apply
强行把this指到某个对象。解决由于环境不同导致this错乱。
call(object, arg1, arg2);
apply(object, argArray);
四、异常处理
function myFunction(){
this.style.color='red';
}
//未捕获异常前
//myFunction();
//捕获异常后
try{
myFuncdtion();
}catch(exception){
alert('捕获的异常名为:' + exception.name
+ '\n捕获的异常信息为:'+ exception.message);
}