广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >基于Vue中this.$options.data()的this指向问题
  • 144
分享到

基于Vue中this.$options.data()的this指向问题

2024-04-02 19:04:59 144人浏览 薄情痞子
摘要

目录this.$options.data()的this指向问题Vue文档中有关于data的指向问题的解释vue骚操作之this.$options.data()重置vue组件的data

this.$options.data()的this指向问题

项目里遇到一个问题,用this.$options.data()重置组件data时报错,原因是因为fORM里的rule规则采用了this写法。

如下:

rules: {
        code: [this.$rules.required()],
        name: [this.$rules.required()],
        age: [
          {min: 1, max: 120, type: 'number', message: '年龄 1 到 120 之间', trigger: 'blur'}
        ],
        email: [
          {type: 'email', message: '邮箱格式不正确', trigger: 'blur'}
        ]
      },

this.$rules是一个自定义全局变量,想到可能是由于this指向的问题导致找不到$rules.required对象了。

首先,我们知道,vue中 this.$options.data() 可以获取原始的data值(只读),this.$data 获取当前状态下的data,在重置data数据时,拷贝重新赋值一下就行了。

如下:

Object.assign(this.$data, this.$options.data());

这是,如果,你的data数据中有采用this的写法,在调用this.$options.data() 就会报错,因为data()内部的this指向不对。

vue文档中有关于data的指向问题的解释

如下:

如果你为 data property 使用了箭头函数,则 this 不会指向这个组件的实例,不过你仍然可以将其实例作为函数的第一个参数来访问。

data: vm => ({ a: vm.myProp })

这是一种方法,还有一种方法是调用时为data函数指定this。

如下:

Object.assign(this.$data, this.$options.data.call(this));

vue骚操作之this.$options.data()

重置vue组件的data数据

在vue单文件组件里有时需要重置data中的数据,比如表单填写一半,用户想重新填写。

<script>
    export default {
        data() {
            return {
                // 表单
                form: {
                    input: ''
                }
            }
        },
        ...
        methods: {
            // 重置表单方法
            retset() {
                this.form = this.$options.data().form;
            }
        },
        ...
    }
</script>

也可以通过给组件 $data 对象赋值来重置来重置整个 $data

this.$data = this.$options.data();

小结一下

vue组件可以通过 this.$options 对象获取你编写的任何方法,比如 created( ) 生命周期函数,发现vue新玩法

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: 基于Vue中this.$options.data()的this指向问题

本文链接: https://www.lsjlt.com/news/141146.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 基于Vue中this.$options.data()的this指向问题
    目录this.$options.data()的this指向问题vue文档中有关于data的指向问题的解释vue骚操作之this.$options.data()重置vue组件的data...
    99+
    2022-11-13
  • Vue中关于this指向的问题示例详解
    目录由Vue管理的函数不被vue管理的函数this指向大致分类总结在Vue中,方法体里用this调用vue实例的数据,有时会指向window,导致调用失败报错。 由Vue管理的函数 ...
    99+
    2022-11-13
  • Vue中methods的this指向问题浅析
    如果是组件的话,将会是VueComponent实例对象,Vue和VueComponent两个类其实差不都,今后会另外开章节描述两者差别,这里先飘过。 比如下面的简单的一个demo代码...
    99+
    2022-11-13
    Vue methods Vue methods this指向
  • JavaScript中的this指向问题详解
    前言 相信我,只要记住本文的 7️⃣ 步口诀,就能彻底掌握 JS 中的 this 指向。 先念口诀:箭头函数、new、bind、apply 和 call、欧...
    99+
    2022-11-12
  • vue如何使用axios时解决关于this指向的问题
    这篇文章将为大家详细讲解有关vue如何使用axios时解决关于this指向的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1.解决办法在vue中使用axios做网络请...
    99+
    2022-10-19
  • Vue props传入function时的this指向问题解读
    目录Vue props传入function时的this指向踩坑笔记我的解决方案Vue props 传递函数Props的type是函数总结Vue props传入function时的th...
    99+
    2023-01-28
    Vue props传入function Vue this指向 Vue props function
  • 如何解决js中this指向问题
    本篇文章给大家分享的是有关如何解决js中this指向问题,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。JS中this指向问题相信我,只要记住本...
    99+
    2022-10-19
  • JavaScript中this指向问题怎么理解
    这篇文章主要介绍“JavaScript中this指向问题怎么理解”,在日常操作中,相信很多人在JavaScript中this指向问题怎么理解问题上存在疑惑,小编查阅了各式资料,...
    99+
    2022-10-19
  • JavaScript 中this指向问题案例详解
    总结 全局环境 ➡️ window 普通函数 ➡️ window 或 undefined 构造函数 ...
    99+
    2022-11-12
  • JavaScript函数中this指向问题详解
    this关键字 哪个对象调用函数,函数里面的this指向哪个对象。 **严格模式下:**在全局环境中,this指向的是undefined **非严格模式下:**在全局环境中,thi...
    99+
    2022-11-12
  • 一文搞懂JavaScript中的this指向问题
    一、全局环境下的this指向在全局作用域下,this始终指向全局对象window,无论是否是严格模式!congsole.log()完整的写法是window.console.log(),window可以省略,window调用了console....
    99+
    2023-05-14
    javascript
  • JS中的this指向问题详细介绍
    这篇文章主要介绍“JS中的this指向问题详细介绍”,在日常操作中,相信很多人在JS中的this指向问题详细介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JS中的this...
    99+
    2022-10-19
  • 一文详解JavaScript中this指向的问题
    目录1. 默认绑定2. 隐式绑定3. 显示绑定4. new 绑定5. 箭头函数的this6. 优先级7. 总结前提:文章讨论的都是非严格模式下this指向 1. 默认绑定 例子1 ...
    99+
    2023-05-14
    JavaScript this指向 JavaScript this
  • JavaScript中this指向问题的示例分析
    这篇文章将为大家详细讲解有关JavaScript中this指向问题的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 箭头函数箭头函数排在第一个是因为它的 this 不会被改变,所以只要当前函数...
    99+
    2023-06-14
  • JavaScript中this指向的问题怎么解决
    今天小编给大家分享一下JavaScript中this指向的问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1. 默...
    99+
    2023-07-05
  • JavaScript中的this指向问题怎么解决
    这篇文章主要介绍了一文搞懂JavaScript中的this指向问题的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇一文搞懂JavaScript中的this指向问题文章都会有所收获,下面我们一起来看看吧。this的...
    99+
    2023-07-04
  • 在Vue中使用防抖与节流,及this指向的问题
    目录使用防抖与节流,及this指向问题一顿操作后使用防抖函数所遇见的坑正常写法使用Vue中写法使用Vue中的watch的防抖简写使用防抖与节流,及this指向问题 最近项目中遇到了防...
    99+
    2022-11-13
  • vue中的this指向有什么用
    小编给大家分享一下vue中的this指向有什么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!vue 中的this 指向?以上是...
    99+
    2022-10-19
  • JavaScriptthis绑定与this指向问题的解析
    目录一、this 绑定怎么理解 this?this 是如何绑定的?this 绑定优先级二、this 指向判断准则判断顺序常见的指向问题三、改变 this 指向有四种方式变量保存 th...
    99+
    2023-02-27
    JavaScript this绑定 JavaScript this指向
  • JS 中在严格模式下 this 的指向问题
    目录前言一、全局作用域中的this二、全局作用域中函数中的this三、对象的函数(方法)中的this四、构造函数的this五、事件处理函数中的this六、内联事件处理函数中的this...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作