this的四种用法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了this的四种用法相关的知识,希望对你有一定的参考价值。

                         

函数运行时,自动生成的一个内部对象,只能在函数内部使用

随着函数使用场合的不同,this的值也发生着改变,但是有一个总原则:this指的是调用函数的那个对象(核心)

  1、纯粹的函数调用

  this指的是全局对象globa

     ex:

  var x = 2;

    function test(){
        var x = 1;
        function error(){
            alert(this.x);
        }
        return error;
}
test();  
2 作为对象的方法调用
ex:
var x = 3; var demo = { x:1, error : function () { var x = 2; function ss(){ alert(this.x); } return ss; } };
demo.error()();
3、作为构造函数调用
function test(){
        this.x = 1;
   }
    var o = new test();
     var x = 2;
alert(o.x);
4,call()和apply()时
ex:
var x = 3; var o = { x:1 }; var v = { x:2, test:function () { return this.x; } }; alert(v.test());
alert(v.test.call()); alert(v.test.call(o));
 

以上是关于this的四种用法的主要内容,如果未能解决你的问题,请参考以下文章

JS中this的四种用法

JS中this的四种用法

JS中this的四种用法

JS种this的四种用法

javascript中this的四种用法

react中ref的四种用法