最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

vue实例方法和数据详解

来源:动视网 责编:小采 时间:2020-11-27 20:07:41
文档

vue实例方法和数据详解

vue实例方法和数据详解:本文主要介绍了vue 实例方法和数据的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下,希望能帮助到大家。1.vm.$set问题描述:如何在不通过循环数据给list数据添加一个showMore属性,并且在moreFun中改变这个新增属性的值,并实现双向绑定?<
推荐度:
导读vue实例方法和数据详解:本文主要介绍了vue 实例方法和数据的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下,希望能帮助到大家。1.vm.$set问题描述:如何在不通过循环数据给list数据添加一个showMore属性,并且在moreFun中改变这个新增属性的值,并实现双向绑定?<


本文主要介绍了vue 实例方法和数据的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下,希望能帮助到大家。

1.vm.$set

问题描述:

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

<template>
 <p id="app">
 <p class="demo">
 <ul>
 <template v-for="(v,index) in list">
 <li>{{v.name}}</li>
 <p v-show="!v.showMore">
 <button @click="moreFun(index)">展示更多</button>
 </p>
 </template>
 </ul>
 </p>
 </p>
</template>
<script>
export default {
 name: 'app',
 data() {
 return {
 list: [{
 name: '小颖'
 }, {
 name: '仔仔'
 }, {
 name: '黑妞'
 }, {
 name: '土豆'
 }]
 }
 },
 methods: {
 moreFun(index) {
 console.log(this.list);
 }
 }
}
</script>
<style>
#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;
}
</style>

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

 <p v-show="!v.showMore">
 <button @click="moreFun(index)">展示更多</button>
 </p>

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

 moreFun(index) {
 this.$set(this.list[index], 'showMore', true);
 console.log(this.list);
 }

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

<template>
 <p id="app">
 <p class="demo">
 <ul>
 <template v-for="(v,index) in list">
 <li>{{v.name}}</li>
 <p v-show="!v.showMore">
 <button @click="moreFun(index)">展示更多</button>
 </p>
 </template>
 </ul>
 </p>
 </p>
</template>
<script>
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);
 }
 }
}
</script>
<style>
#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;
}
</style>

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

<p v-show="!v.showMore"> <button @click="moreFun(index)">展示更多</button> </p>

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

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

2.vm.$watch

用法:

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

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

<template>
 <p id="app">
 <p class="demo">
 <input type="text" class="num1" v-model="num1">
 <label class="sign">-</label>
 <input type="text" class="num2" v-model="num2">
 <label class="sign">=</label>
 <label class="result">{{resultNum}}</label>
 </p>
 </p>
</template>
<script>
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;
 }
}
</script>
<style>
#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;
}
</style>

3.vm.$delete

用法:

这是全局 Vue.delete 的别名。

<template>
 <p id="app">
 <p class="demo">
 <ul>
 <template v-for="(v,index) in list">
 <li>{{v.name}}</li>
 <li>{{v.age}}</li>
 <button @click="deleteFun(index)">delete</button>
 </template>
 </ul>
 </p>
 </p>
</template>
<script>
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');
 }
 }
}
</script>
<style>
#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;
}
</style>

文档

vue实例方法和数据详解

vue实例方法和数据详解:本文主要介绍了vue 实例方法和数据的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下,希望能帮助到大家。1.vm.$set问题描述:如何在不通过循环数据给list数据添加一个showMore属性,并且在moreFun中改变这个新增属性的值,并实现双向绑定?<
推荐度:
标签: 方法 数据 VUE
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top