js函数中this指向的问题

本文详细解释了JavaScript中this关键字的不同行为及其在各种上下文中的指向。涵盖了普通函数、对象方法、定时器回调、构造函数及原型方法等场景,并通过具体示例展示了this的具体指向。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<!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
     * 对象.方法中的this是谁?----当前的实例对象
     * 定时器方法中的this是谁?----window
     * 构造函数中的this是谁?-----实例对象
     * 原型对象方法中的this是谁?---实例对象
     *
     *
     * */


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




   // 普通函数---函数声明
       function f1() {
         console.log(this);
       }
      f1();
   // 普通函数---函数表达式
    var f2= function () {
        console.log(this);
    };
    f2();
    //定时器中的this
       setInterval(function () {
         console.log(this);
       },1000);


   // 构造函数
       function Person() {
         console.log(this);
   // 对象的方法
         this.sayHi=function () {
           console.log(this);
         };
       }
   // 原型中的方法
       Person.prototype.eat=function () {
         console.log(this);
       };
       var per=new Person();
       console.log(per);
       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、付费专栏及课程。

余额充值