温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么在vue中利用this.$set 动态绑定数据

发布时间:2021-01-29 14:55:42 来源:亿速云 阅读:270 作者:Leah 栏目:开发技术

这期内容当中小编将会给大家带来有关怎么在vue中利用this.$set 动态绑定数据,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

<template>   <div>     <!-- 单个数据 -->     <button @click="text0a">text0</button>     <p>text0: {{text0}}</p>     <!-- 对象 -->     <button @click="textObja">textObj</button>     <p>textObj.text1: {{textObj.text1}}</p>     <!-- 数组 -->     <button @click="textArra">textArr</button>     <p>textArr[1]: {{textArr[1]}}</p>     <!-- json数据 -->     <button @click="textJsona">textJson</button>     <p>textJson[1].t5: {{textJson[1].t5}}</p>   </div> </template> <script> export default {   data() {     return{       text0 : '',       textObj: {},       textArr: [],       textJson:[         {t0: ''},         {t4: ''},         {t7: ''},       ]     }   },   methods: {     text0a: function () {       let vm = this       let text100 = 'efghjk'       vm.$set(vm,'text0',text100)        //等效于 vm.$set(vm,'text0','efghjk')     },     textObja: function () {       let vm = this       let textObj100 = {         text1: '123',         text2: '456'         }       vm.$set(vm.textObj,'text1',textObj100.text1)        //此时等效于 vm.$set(vm,'textObj',textObj100)     },     textArra: function () {       let vm = this       let textArr200 = ['a1','a2','a3']       vm.$set(vm,'textArr',textArr200)     },     textJsona: function () {       let vm = this       let textJson300 = [         {t1: 't1',t2: 't2',t3: 't3'},         {t4: 't4',t5: 't5',t6: 't6'},         {t7: 't7',t8: 't8',t9: 't9'},       ]       vm.$set(vm.textJson[1],'t5',textJson300[1].t5)        //此时等效于 vm.$set(vm,'textJson',textJson300)     }   } } </script> <style> </style>

补充:Vue 使用$set动态给数据设置属性

在实际的开发过程中,给表单元素绑定model的时候,绑定的元素的属性是根据后台数据动态生成的。如果使用常规的赋值方式,是无法更新视图的

需要使用

this.$set(dataName,keyName,keyValue)
export default {  data:{   // 先定义一个空对象   formObject:{},   arrayList:[],  },  mounted() {   this.initPage()  },  methods:{   initPage(){    this.$store.dispatch(namespace/callData).then(res=>{     // 给数据设置key-value     res.data.forEach(item=>{      // ❗❗❗❗❗ this.formObject[item.name] = item.value // ❗❗❗❗ 这种方式是不能更新视图的      this.$set(this.formObject, item.name, item.value) // ✅✅✅✅可以更新视图     })    })    // 修改数组     this.$store.dispatch(namespace/callData).then(res=>{     // 给数据设置key-value     this.$set(this.arrayList,0,(res.data)[0].id) ✅✅✅✅可以更新视图    })   }  } }

上述就是小编为大家分享的怎么在vue中利用this.$set 动态绑定数据了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI