JavaScript的4种this调用模式】的更多相关文章

方法调用模式:函数调用模式:构造器调用模式:apply调用模式: 方法调用模式: 当一个函数被保存为对象的一个属性时,我们称它为一个方法.当一个方法被调用时,this被绑定到该对象. 函数调用模式: 以此模式调用函数时,this被绑定到全局对象.使用that方式解决: var add = function(a,b){return a+b;} var myObj = {}; myObj.double = function(){ var that = this; var helper = funct…
最近想起来之前看过的一种js语法,感觉很实用,但是又想不起来具体的写法.然后在网上浏览了一段时间,终于成功的再现了记忆中的那种语法,嗯~,还是那个熟悉的味道! 代码如下: <script> var sexGirl = { name:'Rose', age: 21, getName:function() { alert(this.name); }, getAge:function() { alert(this.age); } }; </script> <body> <…
近来,学习了一下<JavaScript精粹>,读到了函数这章,理清了JavaScript中this在不同调用模式下的指向. 1.Function调用模式:Function是JavaScript的一种引用类型,拥有四种调用模式:方法调用模式,函数调用模式,构造器调用模式,apply(call, bind)调用模式 2.Function的不同调用模式对this产生不同的影响: (1)方法调用模式:Function作为对象的方法被调用.此时,this指向调用Function的对象. var obj…
http://blog.csdn.net/itpinpai/article/details/51004266 this关键字本意:这个.这里的意思.在JavaScript中是指每一个方法或函数都会有一个this对象,this对象是方法(或函数)在执行时的那个环境,也可以说是这个函数在那个作用域下运行的 一共有四种调用模式:方法调用模式(对象属性模式).函数调用模式(就是普通的函数执行).构造调用模式(应该叫实例上的方法模式更好)和apply调用模式. 一.方法调用模式当它为一个对象上的方法的时候…
this指向问题绝对可以排js 的top 5最难和最重点的问题,初学者常常搞不清楚this指向哪里,特别是学过java和c#的人,想当年俺也迷糊了好久,直到遇到蝴蝶书,主要是因为js和主流的面向对象语言java,c#都不同(相似的问题还有new 操作符的问题, 关于new 构构器函数的原理,参见这篇文章: http://www.cnblogs.com/windyfancy/p/5167266.html ),this并不指向当前对象,这是理解this的关键所在,this的指向取决于你是采用何种方式…
1. 函数模式 // this 指向 window 全局对象 2. 方法模式 // this 指向调用这个方法的对象 3. 构造函数模式 // this 指向 new 新创建出来的实例 4. 上下文模式 //在上下文调用模式中,可以修改 this 的值,也就是可以修改函数的调用方法. //使用下面两种方法,可以修改函数调用上下文,也就是 this 的值. 1. apply:函数.apply(对象,[]);(第一个参数是把 this 修改成的对象). 2. call:函数.call(对象,arg1…
方法调用模式: 当一个函数被保存为对象的一个属性时,我们称它为一个方法.当一个方法被调用时,this被绑定到该对象. //方法调用模式 var myObject = { value: 0 , increment: function(inc){ this.value += (typeof inc === 'number') ? inc :1; } }; myObject.increment(); document.writeln(myObject.value); myObject.incremen…
1. 程序异常 ① try-catch语法    测试异常 try-catch语法代码如下: try { 异常代码;     try中可以承重异常代码, console.log(“try”)  出现异常代码后,正确代码不会执行 } catch (e) { console.log(“e:”+e);  try中出现异常在e中展现出来 console.log(“catch”);  只有try中出现异常才执行这段代码 } finally { console.log( 1 );  无论try中有无异常,都…
介绍函数四种调用模式前,我们先来了解一下函数和方法的概念,其实函数和方法本质是一样,就是称呼不一样而已.函数:如果一个函数与任何对象关系,就称该函数为函数.方法:如果一个函数作为一个对象属性存在,我们就称之为方法.接下来就可以开始今天的主体. 1.函数调用模式. 就是通过函数来调用,规范写法为:function fn(){} fn(); 函数中this的指向->window.案例如下: var age = 38; var obj = { age: 18, getAge: function() {…
第一种:函数直接调用执行的模式 function add(a,b){ console.log(this); return a+b; } add(,) //this===window 这里的this指向是window的 第二种:对象方法的调用模式 var people={ name:'wang', sex:'男', eat:function(){ console.log(this); } } people.eat(); //this===对象,对象方法调用时,this指向被调用者 第三种:构造器的…