码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • vm.$set函数的个人总结


    作用:当改变数组中的数据时,data中已经改变,但是页面不能进行实时渲染。

    在这里插入图片描述

     此时通过vm.$set的API来进行数组修改后的页面渲染、

    1.vm.$set有三个参数  vm.$set(target,propertyName/index,value)

    (目标对象,对象的属性名称/数组的下标索引值,要设置的新值)

    使用$set改变数组的值

     this.$set(this.list,0,'4')

    2.常见问题

    1——数组对象通过下标来操作数组中的对象是响应式的

    1. data(){
    2. list:[
    3. { name:"张三",
    4. age:12
    5. },
    6. {
    7. name:"李四",
    8. age:18
    9. }
    10. ]
    11. },
    12. mounted(){
    13. this.list[0].name = "王五"
    14. }

    此时值改变的时候页面也会进行渲染,因为vue的内部针对于数组中对象会通过Object.definProperty来对所有属性进行劫持,来完成响应式,所以数组中对象元素都是响应式的,这里并没有通过数组下标来改变值,只是通过下标来获取相应的对象,而这个对象是响应式的。

    2——利用下标操作数组属性也是响应式的?

    1. data(){
    2. list:[
    3. { name:"张三",
    4. age:12
    5. },
    6. {
    7. name:"李四",
    8. age:18
    9. }
    10. ],
    11. listArr:[1,2,3]
    12. },
    13. mounted(){
    14. this.list[0].name = "王五";
    15. this.listArr[0] = 0;
    16. }
    • 在this.list[0]之后,data中的数据已经改变,但实际上视图并没有更新
    • 执行到this.list[0].name = "王五"的时候,vm会发现这是响应式操作,会执行内部的observe中的setter,然后通知Dep(订阅器)发生了变化,最终更新视图
    • 在对象的更新过程中,检测到数组listArr也发生了变化,但是视图并没有进行更新,此时vm会将listArr的变化也更新到视图

     3.在前面可以发现,不是对象的属性都会被劫持从而称为响应式,为什么还要提供vm.$set来对对象属性进行操作呢?

    对于已经创建的实例,Vue不允许动态添加根级别的·响应式property。但是可以使用vm.$set方法向嵌套对象添加响应式property。

     

     知识来源于https://blog.csdn.net/weixin_43242112/article/details/108561587?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522166056330716782425151887%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=166056330716782425151887&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduend~default-1-108561587-null-null.142^v40^pc_rank_v36,185^v2^control&utm_term=vm.%24set&spm=1018.2226.3001.4187

  • 相关阅读:
    《论文阅读》MOJITALK: Generating Emotional Responses at Scale
    Python语言:算术运算符知识点讲解
    rust迭代器
    Ensembling Off-the-shelf Models for GAN Training(GAN模型迎来预训练时代,仅需1%的训练样本)
    嵌入式面经-数据结构-十大排序
    退税政策线上VR互动科普展厅为税收工作带来了强大活力
    经典算法——直接选择排序
    CAN201-Computer Network
    Jmeter监控插件:监控服务器性能
    10款实用的市场分析工具,你知道几个?
  • 原文地址:https://blog.csdn.net/weixin_49847397/article/details/126353522
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号