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实例。

相关推荐
daols88几秒前
vxe-table 配置 ajax 加载列表数据,配置分页和查询搜索表单
vue.js·ajax·table·vxe-table
纯爱掌门人6 分钟前
别再死磕框架了!你的技术路线图该更新了
前端·架构·前端框架
没头脑的男大9 分钟前
Unet实现脑肿瘤分割检测
开发语言·javascript·ecmascript
丁点阳光16 分钟前
Ract Router v7:最全基础与高级用法指南(可直接上手)
前端·react.js
~无忧花开~25 分钟前
Vue.config.js配置全攻略
开发语言·前端·javascript·vue.js
w***Q3501 小时前
前端跨平台开发工具,Tauri与Electron
前端·javascript·electron
前端一课1 小时前
H5 WebView 文件下载到手机中(仅安卓与 iOS)
前端
幸会同学1 小时前
在Cesium中实现飘动的红旗
javascript·three.js·cesium
默默乄行走1 小时前
wangEditor5在vue中自定义菜单栏--格式刷,上传图片,视频功能
vue.js
G***66911 小时前
前端框架选型:React vs Vue深度对比
vue.js·react.js·前端框架