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

相关推荐
jin1233226 小时前
基于React Native鸿蒙跨平台地址管理是许多电商、外卖、物流等应用的重要功能模块,实现了地址的添加、编辑、删除和设置默认等功能
javascript·react native·react.js·ecmascript·harmonyos
2501_920931706 小时前
React Native鸿蒙跨平台医疗健康类的血压记录,包括收缩压、舒张压、心率、日期、时间、备注和状态
javascript·react native·react.js·ecmascript·harmonyos
落霞的思绪7 小时前
配置React和React-dom为CDN引入
前端·react.js·前端框架
Hacker_Z&Q7 小时前
CSS 笔记2 (属性)
前端·css·笔记
Anastasiozzzz7 小时前
LeetCode Hot100 295. 数据流的中位数 MedianFinder
java·服务器·前端
橙露7 小时前
React Hooks 深度解析:从基础使用到自定义 Hooks 的封装技巧
javascript·react.js·ecmascript
Exquisite.7 小时前
Nginx
服务器·前端·nginx
2501_920931708 小时前
React Native鸿蒙跨平台使用useState管理健康记录和过滤状态,支持多种健康数据类型(血压、体重等)并实现按类型过滤功能
javascript·react native·react.js·ecmascript·harmonyos
打小就很皮...8 小时前
dnd-kit 实现表格拖拽排序
前端·react.js·表格拖拽·dnd-kit
Ulyanov8 小时前
从静态到沉浸:打造惊艳的Web技术发展历程3D时间轴
前端·javascript·html5·gui开发