200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > js函数调用常用方法详解

js函数调用常用方法详解

时间:2021-03-22 00:17:27

相关推荐

js函数调用常用方法详解

web前端|js教程

js函数,调用

web前端-js教程

来源 javascript语言精粹。这不是书上的源代码。

js的函数调用会免费奉送两个而外的参数就是 this 和 arguments 。arguments是参数组,他并不是一个真实的数组,但是可以使用.length方法获得长度。

书上有说4中调用方式:

方法调用模式

函数调用模式

构造器调用模式

apply调用模式

asp进销存系统源码之家,在Ubuntu中用vim,tomcat适合新手入门吗,python爬虫跨域,php技术经理面试题教程,正规seo价格lzw

下面我们来看看一些实例更好理解。

1:方法调用模式

请注意this此时指向myobject。

b2b网站程序源码下载,vscode绿色版下载,ubuntu 安装gmp,tomcat运行js乱码,指定ip 爬虫,php怎么获取js的值,怎么做好seo排名优化,软件网站源码模板,网钛商业模板lzw

/*方法调用模式*/

var myobject={

value:0,

inc:function(){

alert(this.value)

}

}

myobject.inc()

2:函数调用模式

请注意this此时指向window。

1元购源码,vscode goto插件,ubuntu耳机,tomcat攻击原理,根据sqlite 生成代码,兼容ie轮播插件,移动ui前端框架有哪些,python全家桶爬虫教程,php 处理数组,南昌seo外包服务,高仿爱奇艺网站源码,网页两侧对联关闭代码,jQuery登录模板lzw

/*函数调用模式*/

var add=function(a,b){

alert(this)//this被绑顶到window

return a+b;

}

var sum=add(3,4);

alert(sum)

3:构造器调用模式

javascript语言精粹一书建议摒弃这中方式。因为有更好的方式。这里先不介绍。下次发表博文的时候贴出来。

会在这里加一个连接。

/*构造器调用模式 摒弃*/

var quo=function(string){

this.status=string;

}

quo.prototype.get_status=function(){

return this.status;

}

var qq=new quo("aaa");

alert(qq.get_status());

4:apply调用模式

==我们可以来看一个更有用的apply实例。看最下面的代码。

/*apply*/

//注意使用了上面的sum函数

//与myobject

//这中调用方式的优点在于可以指向this指向的对象。

//apply的第一个参数就是this指针要指向的对象

var arr=[10,20];

var sum=add.apply(myobject,arr);

alert(sum);

看这个apply真正应用。bind这是一个绑定时间的函数。

var bind=function(object,type,fn){

if(object.attachEvent){//IE浏览器

object.attachEvent("on"+type,(function(){

return function(event){

window.event.cancelBubble=true;//停止时间冒泡

object.attachEvent=[fn.apply(object)];//----这里我要讲的是这里

//在IE里用attachEvent添加一个时间绑定以后。

//this的指向不是到object对象本身所以。我们绑定的function里的this.id是无法正常工作的。

//但是如果我们用fn.apply(object)

//这里可以看出我们是把apply的第一个对象也就是this的指向变更给了object所以this.id就变成了

//object.id 可以正常工作了。

}

})(object),false);

}else if(object.addEventListener){//其他浏览器

object.addEventListener(type,function(event){

event.stopPropagation();//停止时间冒泡

fn.apply(this)

});

}

}

bind(document.getElementById("aaa"),"click",function(){alert(this.id)});

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。