写点什么

Vue 数组操作 (1),java 设计模式书籍推荐有代码讲解

作者:Java高工P7
  • 2021 年 11 月 10 日
  • 本文字数:1502 字

    阅读完需:约 5 分钟

items: [


{message: 'Foo' },


{message: 'Bar' }


]


}


});


example1.$data.items.push({message : 'test'});


</script>


pop() 删除最后一个元素




example1.$data.items.pop();


shift() 删除第一个元素




example1.$data.items.shift();


unshift() 添加一个元素到数组最前面




example1.$data.items.unshift({message :'hi..'});


splice() 方法用于插入、删除或替换数组的元素




| 参数 | 描述 |


| --- | --- |


| index | 必需。规定从何处添加/删除元素。该参数是开始插入和(或)删除的数组元素的下标,必须是数字。 |


| howmany | 必需。规定应该删除多少元素。必须是数字,但可以是 “0”。如果未规定此参数,则删除从 index 开始到原数组结尾的所有元素。 |


| item1, …, itemX | 可选。要添加到数组的新元素example1.$data.items.splice(0,1,{message:'splice'}); |


sort() 排序(升序)




<ul id="example-1">


<li v-for="item in items" :key="item.id">{{ item }} </li>


</ul>


<script type="text/javascript">


var example1 = new Vue({


el: '#example-1',


data: {


items: [


2,3,4


]


}


});


example1.$data.items.sort();


reverse() 排序(降序)




example1.$data.items.reverse();

重塑数组

变异方法(mutation method),顾名思义,会改变被这些方法调用的原始数组。相比之下,也有非变异(non-mutating method)方法,例如: filter(), concat() 和 slice() 。这些不会改变原始数组,但总是返回一个新数组。当使用非变异方法时,可以用新数组替换旧数组:


example1.items = example1.items.filter(function (item) {


return item.message.match(/Foo/)


})


你可能认为这将导致 Vue 丢弃现有 DOM 并重新渲染整个列表。幸运的是,事实并非如此。 Vue 实现了一些智能启发式方法来最大化 DOM 元素重用,所以用一个含有相同元素的数组去替换原来的数组是非常高效的操作。


filter() 数组元素过滤




<ul id="example-1">


<li v-for="n in even()">{{ n }}</li>


</ul>


<script type="text/javascript">


var example1 = new Vue({


el: '#example-1',


data: {


numbers: [ 1, 2, 3, 4, 5 ]


},


methods : {


even : function(){


return this.numbers.filter(function (number) {


return number % 2 === 0;


});


《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》
浏览器打开:qq.cn.hn/FTe 免费领取
复制代码


}


}


});


</script>

注意事项

由于 JavaScript 的限制, Vue 不能检测以下变动的数组:


当你利用索引直接设置一个项时,例如: vm.items[indexOfItem] = newValue


当你修改数组的长度时,例如: vm.items.length = newLength


为了解决第一类问题,以下两种方式都可以实现和 vm.items[indexOfItem] = newValue 相同的效果, 同时也将触发状态更新:


// Vue.set


Vue.set(example1.items, indexOfItem, newValue)


例子:


<ul id="example-1">


<li v-for="item in items" :key="item.id">{{ item.message }} </li>


</ul>


<script type="text/javascript">


var example1 = new Vue({


el: '#example-1',


data: {


items: [


{message: 'Foo' },


{message: 'Bar' },


{message: 'hcoder'}


]


}


});


//example1.items[3] = {message : 'test...'};


Vue.set(example1.items, 3, {message : 'test...'});


</script>


数组转字符串,字符串转数组,对象转数组,数组转对象


========================================================================================


数组转字符串




var arr = [1,2,3,4,'李明','jerry'];


arr.join()


//"1,2,3,4,李明,jerry"


arr.toString()


//"1,2,3,4,李明,jerry"


arr.join("")


//"1234 李明 jerry"


arr.join("-")


//"1-2-3-4-李明-jerry"


JSON.stringify(arr)


//"[1,2,3,4,"李明","jerry"]"


var x = JSON.stringify(arr)

用户头像

Java高工P7

关注

还未添加个人签名 2021.11.08 加入

还未添加个人简介

评论

发布
暂无评论
Vue 数组操作(1),java设计模式书籍推荐有代码讲解