使用this调用vue中定义的,data中数据或methods中的方法,报错undefined的原因及解决办法

2023-10-30

问题描述

使用this调用vue中定义的data时,报错,这个变量undefined

<template>
    <div>
        <button @click="clicks()">测试按钮</button>
    </div>
</template>

<script>
export default {
    data() {
        return {
            cacheList: [1, 2, 3, 4, 5],
            t: 0//在data中定义了变量t
        }
    },
    methods: {
        clicks() {
            this.cacheList.forEach(function (item, index, arr) {
                console.log(this)//undefined
                this.t = item//t未被定义,报错
            });
        }
    }
}
</script>

报错:
在这里插入图片描述

解决办法

既然知道是this的指向发生了错误,那么,在this发生错误之前,将this使用一个变量存储起来就行
在这里插入图片描述
在这里插入图片描述

原因

参考文章 彻底理解js中this的指向
网上基本的观点是:

this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象

事实上,在大部分的情况下,这种说法是成立的,但是也不绝对,如下:

var o = {
    a:10,
    b:{
        a:12,
        fn:function(){
            console.log(this.a); //12
        }
    }
}
o.b.fn();

这里最终调用fn()方法的是o对象,可是输出中的是b对象的值
应该是这样:

  1. 如果一个函数中有this,但是它没有被上一级的对象所调用,那么this指向的就是window,这里需要说明的是在js的严格版中this指向的不是window(而是undefined),但是我们这里不探讨严格版的问题,你想了解可以自行上网查找。
  2. 如果一个函数中有this,这个函数有被上一级的对象所调用,那么this指向的就是上一级的对象。
  3. 如果一个函数中有this,这个函数中包含多个对象,尽管这个函数是被最外层的对象所调用,this指向的也只是它上一级的对象
  4. this永远指向的是最后调用它的对象,也就是看它执行的时候是谁调用的

还有一个需要注意的点:

var o = {
    a:10,
    b:{
        a:12,
        fn:function(){
            console.log(this.a); //undefined
            console.log(this); //window
        }
    }
}
var j = o.b.fn;
j();

原因:this永远指向的是最后调用它的对象,也就是看它执行的时候是谁调用的

在我出现的问题中,我没有使用严格模式,但是出现this是undefined的情况呢?参考文章 : vue中的this指向

在JS的框架下,vue中this的指向有以下规则
1、 data中的this指向window 所有的生命周期函数中的this都指向vue实例对象
2、vue的v-on指令中可以接收JS语句,其中的this是window(vue组件中的v-on指令除外)
3、 computed中的this指向vue实例对象
methods中的this有以下几种情况
1、普通函数的this指向vue实例对象
2、箭头函数没有自己的this,因此this指向其宿主对象的this(注意宿主对象是函数对象(它被调用后this的指向要进行具体分析),简单对象没有this
3、普通函数形式的回调函数的this是window,箭头函数形式的回调函数的this遵循箭头函数的原则(大多数情况下是vue实例对象)

由于我在foresch中使用的是匿名函数,匿名函数属于简单函数(简单函数不包括箭头函数),简单函数对象是没有this的,所以上述报错undefined

其实我出现的报错还有一个解决办法,就是将匿名函数变成箭头函数(原因:箭头函数没有自己的this,因此this指向其宿主对象的this)
在这里插入图片描述
这样,this就会指向他的上一级,也就是vue了

在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用this调用vue中定义的,data中数据或methods中的方法,报错undefined的原因及解决办法 的相关文章

随机推荐

  • srand((unsigned int)time(NULL))的理解(C语言)

    在c语言中 碰到这句函数 srand unsigned int time NULL 的理解 目录 1 srand与rand的关系 2 time函数的用法 3 取任意数 1 srand与rand的关系 在C中srand函数经常跟rand函数一
  • 经典/最新计算机视觉论文及代码推荐

    今日推荐几篇最新 经典计算机视觉方向的论文 涉及诸多方面 都是CVPR2022录用的文章 具体内容详见论文原文和代码链接 Convnet新活力 论文题目 A ConvNet for the 2020s 论文链接 https arxiv or
  • python中debug断点调试

    python Debug 断点调试 断点 break point 是指在代码中指定位置 当程序运行到此位置时变中断下来 并让开发者可查看此时各变量的值 因断点中断的程序并没有结束 可以选择继续执行 方法1 脚本中运行 在需要设置断点的地方
  • commonjs, es6 module什么是循环依赖?

    什么是循环依赖 循环依赖是指模块A依赖于模块B 同时模块B依赖于模块A 比如下面这个例子 foo js const bar require bar js console log value of bar bar module exports
  • 使用亚马逊云科技人工智能内容审核服务,打造安全的图像生成和扩散模型

    生成式人工智能技术发展日新月异 现在已经能够根据文本输入生成文本和图像 Stable Diffusion 是一种文本转图像模型 可让您创建栩栩如生的图像应用 您可以通过 Amazon SageMaker JumpStart 使用 Stabl
  • vue3介绍,Vue3的新特性

    vue3的优势 Vue 是目前国内开发最火的前端框架之一 react vue angular的下载趋势 Vue3性能更高 体积更小 Vue的compositionAPI 组合式API 可以 更好的代码复用 方便构建大型项目 对TS的支持比较
  • 通过DButils与连接池C3P0实现对对数据库的增删改查操作

    需要准备的有 C3P0配置文件
  • Excel匹配两列相同内容到同一行

    1 打开一个excel文件 找到需要自动对齐的两列数据 这里根据需要模拟了两列 2 用鼠标左键单击选中C1单元格 3 在C1单元格内输入公式 IF COUNTIF B 1 B 156 A1 0 A1 4 输入完公式后回车 再次选中C1单元格
  • k8s面试题大全(持续更新中)

    目录 前言 docker的工作原理是什么 讲一下 docker的组成包含哪几大部分 docker与传统虚拟机的区别什么 docker技术的三大核心概念是什么 centos镜像几个G 但是docker centos镜像才几百兆 这是为什么 讲
  • Bootstrap验证

    1 readonly验证需要 重新更新 var bootstrapValidator notice info input form data bootstrapValidator bootstrapValidator updateStatu
  • MySql安装版安装最新教程(附错误解决 )

    目录 1 安装版自定义安装 2 问题总结 1 安装版自定义安装 如果需要安装版安装 可参考另一篇博客 MySql压缩版安装最新教程 附错误解决 链接 MySql官网 滑到最下面 上面的是企业版下载 需要付费 我们下载开源的社区版 在这里我下
  • 编译出现 WARNING: ‘aclocal-1.15‘ is missing on your system.问题解决

    最近在中标麒麟下编译opus 1 2 1 make时出现了WARNING aclocal 1 15 is missing on your system 问题 发现是版本问题 于是重新安装了automake 下面是安装过程 1 下载安装包 h
  • PID恒温控制

    1 PID三个环节的作用 PID三个环节各自的主要作用和效应 比例环节 起主要控制作用 使控制量向目标值靠拢 但可能导致振荡 积分环节 消除稳态误差 但会增加超调量 微分环节 产生阻尼效果 抑制振荡和超调 但会降低响应速度 2 比例系数与积
  • @NotEmpty、@NotBlank、@NotNull 区别和使用

    首先需要说明下 本提到的 NotEmpty NotBlank NotNull 分别是 javax validation constraints NotEmpty javax validation constraints NotBlank j
  • Menu菜单,MenuBar菜单栏,MenuItem菜单项

    Menu菜单 MenuBar菜单栏 MenuItem菜单项 菜单栏 public class MenuDemo public static void main String args Frame f new Frame Menu菜单 Men
  • WEB攻防-通用漏洞&水平垂直越权&购买逻辑漏洞

    目录 水平垂直越权 水平越权 垂直越权 访问控制原理 漏洞判别 防护 购买逻辑漏洞 知识点 详细介绍 防护 案例演示 优惠券 案例演示 CMS 订单修改 水平垂直越权 水平越权 同级用户权限共享 当用户访问数据时未对用户和id值进行有效的查
  • Qt-QPointer的使用

    在使用Qt的时候 你是否遇到过这样的场景 从外部传来一个QObject的指针 当使用这个指针的时候 害怕它已经被释放了 如果我们在一个对象A中引用了另一个对象B 当对象B被析构的时候 A对象其实是不知道B已经被析构 这个时候再使用B的话就会
  • 【技术分享】如何实现功能完备性能优异的RTMP、RTSP播放器?

    技术背景 这几年 我们对接了太多有RTSP或RTMP直播播放器诉求的开发者 他们当中除了寻求完整的解决方案的 还有些是技术探讨 希望能借鉴我们播放端的开发思路或功能特性 完善自己的产品 忙里偷闲 今天我们就再聊一聊老生常谈的问题 如何实现功
  • IntelliJ IDEA 2023.2.1 Android开发变化

    IntelliJ IDEA 2023 2 1之前的版本 Empty Activity是指Empty View Activity 而现在Empty Activity是指Empty Compose Activity 另外多了一个Empty Vi
  • 使用this调用vue中定义的,data中数据或methods中的方法,报错undefined的原因及解决办法

    问题描述 使用this调用vue中定义的data时 报错 这个变量undefined