最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

小议Function.apply()之一------(函数的劫持与对象的复制)_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 20:33:54
文档

小议Function.apply()之一------(函数的劫持与对象的复制)_javascript技巧

小议Function.apply()之一------(函数的劫持与对象的复制)_javascript技巧:关于对象的继承,一般的做法是用复制法: Object.extend 见protpotype.js 的实现方法: 代码如下:Object.extend = function(destination, source) { for (property in source) { destination[property] = so
推荐度:
导读小议Function.apply()之一------(函数的劫持与对象的复制)_javascript技巧:关于对象的继承,一般的做法是用复制法: Object.extend 见protpotype.js 的实现方法: 代码如下:Object.extend = function(destination, source) { for (property in source) { destination[property] = so


关于对象的继承,一般的做法是用复制法: Object.extend

见protpotype.js 的实现方法:

代码如下:Object.extend = function(destination, source) {
for (property in source) {
destination[property] = source[property];
}
return destination;
}
除此以外,还有一种不太常见的方法: Function.apply.

apply 方法能劫持(<> 书中用到"劫持"一语,很生动啊)另外一个对象的方法,
继承另外一个对象的属性。
示范代码如下:
Apply示范代码
代码如下:

function Person(name,age){ //定义一个类,人类
this.name=name //名字
this.age=age //年龄
this.sayhello=function(){alert("hello")}
}

function Print(){ //显示类的属性
this.funcName="Print"
this.show=function(){
var msg=[]
for(var key in this){
if (typeof(this[key])!="function") msg.push([key,":",this[key]].join(""))
}
alert(msg.join("\n"))
}
}

function Student(name,age,grade,school){ //学生类
Person.apply(this,arguments)
Print.apply(this,arguments)
this.grade=grade //年级
this.school=school //学校
}

var p1=new Person("jake",10)
p1.sayhello()

var s1=new Student("tom",13,6,"清华小学")
s1.show()
s1.sayhello()
alert(s1.funcName)
学生类本来不具备任何方法,但是在 Person.apply(this,arguments) 后,他就具备了 Person类的sayhello方法和
所有属性。 在 Print.apply(this,arguments) 后就自动得到了 show() 方法。


本文,作为抛砖引玉,只对 apply 的用法(在对象继承和函数劫持方面)做个小示范,其他更深入的应用要
靠大家慢慢去领会了。

文档

小议Function.apply()之一------(函数的劫持与对象的复制)_javascript技巧

小议Function.apply()之一------(函数的劫持与对象的复制)_javascript技巧:关于对象的继承,一般的做法是用复制法: Object.extend 见protpotype.js 的实现方法: 代码如下:Object.extend = function(destination, source) { for (property in source) { destination[property] = so
推荐度:
标签: 的技巧 函数 ()
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top