list vue 添加数据方法_详解vue 实例方法和数据

1.vm.$set

问题描述:

如何在不通过循环数据给list数据添加一个showmore属性,并且在morefun中改变这个新增属性的值,并实现双向绑定?

  • {{v.name}}

展示更多

export default {

name: 'app',

data() {

return {

list: [{

name: '小颖'

}, {

name: '仔仔'

}, {

name: '黑妞'

}, {

name: '土豆'

}]

}

},

methods: {

morefun(index) {

console.log(this.list);

}

}

}

#app {

font-family: 'avenir', helvetica, arial, sans-serif;

-webkit-font-smoothing: antialiased;

-moz-osx-font-smoothing: grayscale;

text-align: center;

color: #2c3e50;

margin-top: 60px;

}

一开始小颖并不知道怎么做,而且小颖觉得

展示更多

这段代码肯定会报错,然而当小颖写上后发现,并没有,后来那位帅锅告诉我,看看vue的  vm.$set     小颖看后将morefun方法写为:

morefun(index) {

this.$set(this.list[index], 'showmore', true);

console.log(this.list);

}

然后就达到小颖想要的结果啦。小颖当时遇到的问题类似于这样的:

  • {{v.name}}

展示更多

export default {

name: 'app',

data() {

return {

list: [{

name: '小颖'

}, {

name: '仔仔'

}, {

name: '黑妞'

}, {

name: '土豆'

}]

}

},

mounted: function() {

this.list.foreach(function(element, index) {

element.showmore = false;

});

},

methods: {

morefun(index) {

this.list[index].showmore = true;

console.log(this.list);

}

}

}

#app {

font-family: 'avenir', helvetica, arial, sans-serif;

-webkit-font-smoothing: antialiased;

-moz-osx-font-smoothing: grayscale;

text-align: center;

color: #2c3e50;

margin-top: 60px;

}

问题:当执行完morefun方法后,虽然list中的showmore属性的值变成了true,但是

展示更多

按钮 展示更多  仍然显示着,这是因为,如果在实例创建之后添加新的属性到实例上,它不会触发视图更新。

所以后来小颖就将showmore直接添加到list中,然后就好啦。现在想想其实用个vm.$set就解决啦。

2.vm.$watch

用法:

观察 vue 实例变化的一个表达式或计算属性函数。回调函数得到的参数为新值和旧值。表达式只接受监督的键路径。对于更复杂的表达式,用一个函数取代。

注意:在变异 (不是替换) 对象或数组时,旧值将与新值相同,因为它们的引用指向同一个对象/数组。vue 不会保留变异之前值的副本。

-

=

{{resultnum}}

export default {

name: 'app',

data() {

return {

num1: 1,

num2: 5,

resultnum: null

}

},

watch: {

num1: function() {

var _num1 = parseint(this.num1);

var _num2 = parseint(this.num2);

this.resultnum = _num1 - _num2;

},

num2: function() {

var _num1 = parseint(this.num1);

var _num2 = parseint(this.num2);

this.resultnum = _num1 - _num2;

}

},

mounted: function() {

var _num1 = parseint(this.num1);

var _num2 = parseint(this.num2);

this.resultnum = _num1 - _num2;

}

}

#app {

font-family: 'avenir', helvetica, arial, sans-serif;

-webkit-font-smoothing: antialiased;

-moz-osx-font-smoothing: grayscale;

text-align: center;

color: #2c3e50;

margin-top: 60px;

}

input.num1,

input.num2 {

width: 100px;

}

label.sign {

font-size: 30px;

vertical-align: -3px;

}

label.result {

font-size: 20px;

}

3.vm.$delete

用法:

这是全局 vue.delete 的别名。

  • {{v.name}}
  • {{v.age}}

delete

export default {

name: 'app',

data() {

return {

list: [{

name: '小颖',

age:22

}, {

name: '仔仔',

age:1

}, {

name: '黑妞',

age:1

}, {

name: '土豆',

age:1

}]

}

},

methods: {

deletefun(index) {

this.$delete(this.list[index], 'age');

}

}

}

#app {

font-family: 'avenir', helvetica, arial, sans-serif;

-webkit-font-smoothing: antialiased;

-moz-osx-font-smoothing: grayscale;

text-align: center;

color: #2c3e50;

margin-top: 60px;

}

总结

以上所述是小编给大家介绍的vue 实例方法和数据,希望对大家有所帮助

希望与广大网友互动??

点此进行留言吧!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值