Vue回调函数中的this

2025/4/25

示例

一个例子------计数器,通过this来操作数据。

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script>
    <title>回调函数中的this</title>
</head>
<body>
    <div id="app">
        <h1>{{msg}}</h1>
        <h1>计数器:{{count}}</h1>
        <button @click="addOne">加一</button>
    </div>
    
    <script>
        new Vue({
            el : "#app",
            data:{
                msg: "回调函数中的this",
                count:0
            },
            methods:{
                addOne(){
                    this.count++
                }
            }
        })
    </script>
    
</body>
</html>

Vue(vm) 和 this的关系

html 复制代码
methods:{
    addOne(){
        this.count++
        console.log(this === vm)
    }
}

所以不难发现。其实vm(vue实例对象) 和this是一个东西,所以其实我们也可以使用

html 复制代码
vm.count++

来实现,但是一般更加常使用this。this就是vm,vm可以访问count通过数据代理。

箭头函数

html 复制代码
<body>
    <div id="app">
        <h1>{{msg}}</h1>
        <h1>计数器:{{count}}</h1>
        <button @click="addOne1">加一1</button>
        <button @click="addOne2">加一2</button>
    </div>
    
    <script>
        const vm = new Vue({
            el : "#app",
            data:{
                msg: "回调函数中的this",
                count:0
            },
            methods:{
                addOne1(){
                    this.count++
                },
                addOne2:()=>{
                    this.count++
                }
            }
        })
    </script>
    
</body>

当使用箭头函数之后,计数器失效。因为箭头函数中没有this,箭头函数中的this是从父级作用域当中继承过来的。对于当前程序来说,父级作用域是全局作用域:window。

普通函数的this指向取决于函数的调用方式。当函数作为对象的方法调用时,this指向该对象;在全局作用域中调用函数,this指向全局对象。addOne1是一个普通函数,能够根据调用方式来决定this的指向,上述的调用是作为Vue实例对象的方法调用 ,所以this指向该Vue实例

但箭头函数不具备自己独立的this绑定,它的this是在定义时从父级作用域继承而来的,且不会被调用方式影响。addOne2 箭头函数定义于 methods 对象里 ,不过 methods 对象本身并非一个函数作用域 ,所以**addOne2 的父级作用域就是全局作用域**。而全局作用域中并没有属性count。

所以在methods中尽量的不使用箭头函数,我们常需要在回调函数中使用到this和vm实例。

相关推荐
伍哥的传说32 分钟前
鸿蒙系统(HarmonyOS)应用开发之手势锁屏密码锁(PatternLock)
前端·华为·前端框架·harmonyos·鸿蒙
yugi98783834 分钟前
前端跨域问题解决Access to XMLHttpRequest at xxx from has been blocked by CORS policy
前端
浪裡遊1 小时前
Sass详解:功能特性、常用方法与最佳实践
开发语言·前端·javascript·css·vue.js·rust·sass
旧曲重听12 小时前
最快实现的前端灰度方案
前端·程序人生·状态模式
默默coding的程序猿2 小时前
3.前端和后端参数不一致,后端接不到数据的解决方案
java·前端·spring·ssm·springboot·idea·springcloud
夏梦春蝉2 小时前
ES6从入门到精通:常用知识点
前端·javascript·es6
归于尽2 小时前
useEffect玩转React Hooks生命周期
前端·react.js
G等你下课2 小时前
React useEffect 详解与运用
前端·react.js
我想说一句2 小时前
当饼干遇上代码:一场HTTP与Cookie的奇幻漂流 🍪🌊
前端·javascript
funnycoffee1232 小时前
Huawei 6730 Switch software upgrade example版本升级
java·前端·华为