[Object]面向对象编程(ITCAST版)

作者:zccst

一、[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);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值