返回顶部
首页 > 资讯 > 精选 >Vue的$set怎么实现
  • 227
分享到

Vue的$set怎么实现

2023-07-04 19:07:12 227人浏览 安东尼
摘要

这篇文章主要讲解了“Vue的$set怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue的$set怎么实现”吧!应用场景 let dataArr =&n

这篇文章主要讲解了“Vue的$set怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue的$set怎么实现”吧!

应用场景

 let dataArr = ["item1"]; let dataObject = {      name: "ccs"    };    dataArr[2] = "item2";    dataObject.age = 22;    响应失败,页面没有显示更新新增的数据    this.$set(this.dataArr,2,'item2')    this.$set(this.dataObject,'age',22)    响应成功,页面显示更新新增的数据

set实现

接下来我们看一下$set在Vue中的定义

function set(target: Array<any> | Object, key: any, val: any): any {  if (    process.env.node_ENV !== "production" &&    (isUndef(target) || isPrimitive(target))  ) {    warn(      `Cannot set Reactive property on undefined, null, or primitive value: ${(target: any)}`    );  }  if (Array.isArray(target) && isValidArrayIndex(key)) {    target.length = Math.max(target.length, key);    target.splice(key, 1, val);    return val;  }  if (key in target && !(key in Object.prototype)) {    target[key] = val;    return val;  }  const ob = (target: any).__ob__;  if (target._isVue || (ob && ob.vmCount)) {    process.env.NODE_ENV !== "production" &&      warn(        "Avoid adding reactive properties to a Vue instance or its root $data " +          "at runtime - declare it upfront in the data option."      );    return val;  }  if (!ob) {    target[key] = val;    return val;  }  defineReactive(ob.value, key, val);  ob.dep.notify();  return val;}

源码中首先判断set的目标是否是undefined基本类型如果是undefined基本类型就报错,
因为用户不应该往undefined和基本类型中set东西
然后又判断了目标是否是数组与key是不是合法的index,合法的index是指值为大于等于0的整数,
如果两个条件都成立就对目标数组调用splice方法插入或者修改数组
这里的splice不是普通的splice是王维诗里的splice,是被vue代理重写过的splice

数组实现响应

$set实现数组修改响应的方式是代理重写的数组的一部分方法,接下来我们看一下具体实现

const arrayProto = Array.prototypeexport const arrayMethods = Object.create(arrayProto)const methodsToPatch = [  'push',  'pop',  'shift',  'unshift',  'splice',  'sort',  'reverse']function def(obj, key, val, enumerable) {    Object.defineProperty(obj, key, {        value: val,        enumerable: !!enumerable,        writable: true,        configurable: true    });}methodsToPatch.forEach(function (method) {  const original = arrayProto[method]  def(arrayMethods, method, function mutator (...args) {    const result = original.apply(this, args)    const ob = this.__ob__    let inserted    switch (method) {      case 'push':      case 'unshift':        inserted = args        break      case 'splice':        inserted = args.slice(2)        break    }    if (inserted) ob.observeArray(inserted)    ob.dep.notify()    return result  })})

vue中代理重写的不只是splice,有push、pop、shift、unshift、splice、sort、reverse这七个方法,首先执行了const result = original.apply(this, args)执行原本数组的方法并获取它的值,接下来判断如果是往数组中添加值就将新添加的值也实现响应式,
最后一步拿到这个数组的_ob_对象_ob_里的dep进行派发更新。
想深入了解vue的响应式可以查阅往期文章
面试官问你Vue2的响应式原理,你怎么答? - 掘金 (juejin.cn)

对象实现响应

$set中下半部分的逻辑就是用来处理对象响应的,我们接着往下看

  if (key in target && !(key in Object.prototype)) {    target[key] = val;    return val;  }  const ob = (target: any).__ob__;  if (!ob) {    target[key] = val;    return val;  }  defineReactive(ob.value, key, val);  ob.dep.notify();  return val;

首先判断了属性如果在目标对象中直接return结束逻辑,
因为vue只有添加目标对象中原本没有的属性时才会失去响应
例如 let obj={}  obj.name='ccs'
vue在初始化的时候会将data里的所有属性都变成响应式,如果的值是对象或者数组则会new一个Observer实例储存在__ob__,想深入了解vue的响应式可以查阅往期文章
面试官问你Vue2的响应式原理,你怎么答? - 掘金 (juejin.cn)
拿到这个对象的_ob_进行判断,如果不存在就说明是未经过vue初始化的普通对象而不是响应式对象否则就手动通过defineReactive为属性添加get方法与set方法实现响应
然后手动调用dep里的notify()发布更新。

感谢各位的阅读,以上就是“Vue的$set怎么实现”的内容了,经过本文的学习后,相信大家对Vue的$set怎么实现这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: Vue的$set怎么实现

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

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

猜你喜欢
  • Vue的$set怎么实现
    这篇文章主要讲解了“Vue的$set怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue的$set怎么实现”吧!应用场景 let dataArr =&n...
    99+
    2023-07-04
  • vue $set怎么使用
    这篇文章主要讲解了“vue $set怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue $set怎么使用”吧!代码如下:<!-- 操作 -->&nb...
    99+
    2023-07-04
  • 聊聊Vue中$set是如何实现的?
    应用场景 let dataArr = ["item1"]; let dataObject = { name: "ccs" }; dataArr[2] = "i...
    99+
    2023-05-14
    Vue.js
  • vue中怎么利用$set和$delete实现数据监控
    本篇文章给大家分享的是有关vue中怎么利用$set和$delete实现数据监控,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。<!DOCT...
    99+
    2024-04-02
  • 怎么用vue的$set实现给数组集合对象赋值
    这篇“怎么用vue的$set实现给数组集合对象赋值”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看...
    99+
    2024-04-02
  • vue中this.$set怎么用
    这篇文章给大家分享的是有关vue中this.$set怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。vue中 this.$set的使用背景:在我写前端项目的时候,后端给我们的一个json对象,并且我已经渲染在...
    99+
    2023-06-25
  • java中set转list怎么实现
    可以通过以下方式将Set转换为List: 使用ArrayList构造函数: Set<String> set = ne...
    99+
    2024-03-13
    java
  • Vue中的Vue.set和this.$set怎么使用
    这篇文章主要介绍“Vue中的Vue.set和this.$set怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue中的Vue.set和this.$set怎么使用”文章能帮助大家解决问题。一、...
    99+
    2023-06-29
  • 你知道Vue中神奇的$set是如何实现的吗?
    目录前言应用场景set实现数组实现响应对象实现响应总结前言 在日常开发中,$set的也是一个非常实用的API,因为Vue2实现响应式的核心是利用了ES5的Object.defineP...
    99+
    2022-12-14
    Vue实现$set Vue $set
  • vue $set 实现给数组集合对象赋值
    vue $set 数组集合对象赋值 在vue自定义数组对象集合中,想要给每个数组对对象再添加一个属性和值。 // data定义一个集合对象 responseData:[ ...
    99+
    2024-04-02
  • node怎么使用ES6中的set实现去重
    这篇文章主要为大家展示了“node怎么使用ES6中的set实现去重”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“node怎么使用ES6中的set实现去重”这篇文...
    99+
    2024-04-02
  • Vue.$set失效问题怎么解决
    这篇“Vue.$set失效问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue...
    99+
    2024-04-02
  • vue怎么实现的跨域
    随着前端技术的不断发展,前端工程师们在制作网站时经常需要通过Ajax请求来获取数据。在这个过程中,很容易遇到跨域问题。本文将介绍Vue.js如何实现跨域请求的方式。JSONP跨域JSONP(JSON with Padding)是一种跨域数据...
    99+
    2023-05-18
  • vue vue-esign签字板的demo怎么实现
    本篇内容主要讲解“vue vue-esign签字板的demo怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue vue-esign签字板的demo怎么实现”吧!vu...
    99+
    2023-06-30
  • vue $set如何实现给数组集合对象赋值
    本篇内容主要讲解“vue $set如何实现给数组集合对象赋值”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue $set如何实现给数组集合对象赋值”吧!vue $set 数组集合对象赋值在vu...
    99+
    2023-06-20
  • 怎么实现Vue的响应式
    这篇文章主要介绍了怎么实现Vue的响应式,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。简易版 以watch为切入点watch是平时开发中使用...
    99+
    2024-04-02
  • Golang怎么使用Map实现去重与set的功能
    这篇文章将为大家详细讲解有关Golang怎么使用Map实现去重与set的功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。golang的优点golang是一种编译语言,可以将代码编译为机器代码,编译后的二...
    99+
    2023-06-14
  • JavaScript如何实现Set
    小编给大家分享一下JavaScript如何实现Set,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Set简单实现window.Set = wi...
    99+
    2023-06-03
  • vue防抖怎么实现
    这篇文章主要介绍“vue防抖怎么实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue防抖怎么实现”文章能帮助大家解决问题。1.首先新建一个 debounce.js 代码如下const debou...
    99+
    2023-06-27
  • Vue插槽怎么实现
    这篇文章主要介绍“Vue插槽怎么实现”,在日常操作中,相信很多人在Vue插槽怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue插槽怎么实现”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!一、样例代...
    99+
    2023-07-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作