`
zccst
  • 浏览: 3292773 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

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

 
阅读更多
作者:zccst

一、公有、静态、私有和特殊 属性/方法
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);
}
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics