南城& 2022-09-08 19:03 采纳率: 70.6%
浏览 31
已结题

为什么第一种function(){}就不可以,第二种箭头函数就可以让counter+1?

问题:为什么第一种function(){}就不可以,第二种箭头函数就可以让counter+1?

代码


```html
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://unpkg.com/vue@next"></script>
</head>

<body>
    <div id="counter">
        Counter:{{counter}}
    </div>
    
    <script>
        const Counter = {
            data(){
                return{
                    counter:1
                }
            },
            // 第一种方式
            // mounted(){
            //     setInterval(function(){
            //         this.counter++
            //     },1000)
            // }
            // 第二种方式
            mounted(){
                setInterval(()=>{
                    this.counter++
                },1000)
            }
        }
        Vue.createApp(Counter).mount('#counter')
    </script>
</body>

</html>


```

  • 写回答

4条回答 默认 最新

  • SmallAntJ 2022-09-08 21:18
    关注

    匿名函数的作用域是全局的,也就是说第一种方式中的this并不指向Counter变量,而是整个script。可以在mounted函数中先获得this再传入,代码可以改成:

    mounted(){
        var that = this
        setInterval(function(){
            that.counter++
        },1000)
    }
    

    而箭头函数没有这个问题,它直接使用mounted的作用域,也就指向了Counter变量

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 9月20日
  • 已采纳回答 9月12日
  • 创建了问题 9月8日

悬赏问题

  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等
  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥20 测距传感器数据手册i2c