Js中this指向问题

this指向问题

  • 普通函数中的this是谁?-----window

  • 对象.方法中{per.sayHi();}的this是谁?----当前的实例对象

  • 定时器方法中的this是谁?----window

  • 构造函数中的this是谁?-----实例对象

  • 原型对象方法中的this是谁?---实例对象

举例如下:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
  <title>Document</title>
</head>
<body>

</body>
</html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>title</title>
  <script>

    /*
     *
     * 函数中的this的指向
     *
     *
     * 普通函数中的this是谁?-----window
     * 对象.方法中{per.sayHi();}的this是谁?----当前的实例对象
     * 定时器方法中的this是谁?----window
     * 构造函数中的this是谁?-----实例对象
     * 原型对象方法中的this是谁?---实例对象
     *
     * */
    //BOM:中顶级对象是window,浏览器中所有的东西都是window的

//    严格模式函数指向:
//            "use strict";//严格模式
    function f1() {
      console.log(this); //window
    }
    window.f1();
//

    //  严格模式函数指向:
    "use strict";//严格模式
    function f1() {
        console.log(this); //undefined
    }
    f1();
    //


//    普通函数
    function f1() {
      console.log(this); //window
    }
    f1(); //相当于 window.f1();

//    定时器中的this
    setInterval(function () {
      console.log(this);  //window
    },1000);


//    构造函数
    function Person() {
      console.log(this); //Person
      this.sayHi=function () {    // 对象的方法
        console.log(this);//Person
      };
    }


//    原型中的方法
    Person.prototype.eat=function () {
      console.log(this);//Person
    };
    var per=new Person();
    console.log(per); //Person
    per.sayHi();
    per.eat();


    //BOM:中顶级对象是window,浏览器中所有的东西都是window的
  </script>
</head>
<body>


</body>
</html>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值