简单了解vue.js数组的常用操作


Posted in Javascript onJune 17, 2019

数组的相关方法如下

1,锁定数组的长度(只读模式)[ Array.join() ]

var a = [1,2,3] //定义一个数组<br>
Object.defineProperty(a,"length",{
writable:false
}) //将a数组的长度属性设为只读<br>
a.length = 0 //将a的长度改为0<br>
console.log(a.length); //打印a数组的长度,还是3

2、将数组合并成字符串(返回字符串)[ Array.join() ]

var a = [1,2,3];
var b = a.join("");
console.log(a); //[1, 2, 3],原数组不改变
console.log(b); //"123",变成字符串

3、返回逆序数组(倒叙排列数组)[ Array..reverse() ]

var a = [1,2,3];
a.reverse();
console.log(a); //直接改变a数组的值 返回的是[3,2,1]

4、Array.sort()方法,返回排序后的数组。如果数组包含undefined,会被排到数组的尾部。如果不带参数的调用sort(),数组元素以字母表顺序排序。

从大到小排列
var a = [2,33,1111,444]; 
a.sort() 
console.log(a); //返回的结果是[1111, 2, 33, 444]
从小到大排列
var a = [2,33,1111,444]; 
a.sort(function (a,b) {
return a-b
}) 
console.log(a); //[2, 33, 444, 1111]

5、Array.concat(),创建并返回一个新数组

var a = [1,2,3]; 
var b = a.concat(4,5); 
var c = a.concat([4,5]); 
console.log(a); //返回的还是[1,2,3]
console.log(b); //返回[1,2,3,4,5] 
console.log(c); //返回[1,2,3,4,5]
// 复制数组
var a = [1,2,3]; 
var b = a.concat(); 
console.log(a); //返回[1,2,3] 
console.log(b); //返回[1,2,3]

6、Array.slice()方法,返回指定数组的片段或者子数组。不会改变原数组

var a = [1,2,3,4,5];<br>
a.slice(0,3); //返回[1,2,3] 第一个参数是截取开始的位置(包括),第二个参数是截取结束的位置(不包括) 
a.slice(3); //返回[4,5] 
a.slice(1,-1); //返回[2,3,4] 负数表示倒数 
console.log(a); //返回[1,2,3,4,5]

7、Array.splice()方法,用来删除或插入元素,会修改原数组!

数组的起始位置为0
var a = [1,2,3,4,5,6,7,8]; 
var b = a.splice(1,2); //第一个参数是截取的起始位置(包括),第二个参数是截取的个数,之后的参数就是添加在元数组的新值 
console.log(a); //返回[1, 4, 5, 6, 7, 8] 
console.log(b); //返回[2, 3]

可以用来解决在数组起始部位加入数据

this.noticeMessageList.splice(0, 0, { fromUser: 'zhangq1',
noticeMessage: '此处添加message'})

8、push()方法与pop()方法

push()方法在数组的尾部添加一个或者多个元素,并返回数组的新长度。注意的是,改变的是原数组的值,返回的是新数组的长度。

pop()方法删除数组的最后一个元素,并返回它的删除值。也是改变原数组,返回的是删除的值。

9、unshift()方法与shift()方法

unshift()方法类似于push()不同的是,他是在数组头部添加,其他都一样

shift()方法则类比pop()方法。

10、toString()和toLocaleString()

toString()方法将每个元素转化为字符串,类似于不传参的join()方法。

toLocaleString()方法是toString()的本地化版本。

11、forEach()方法,从头至尾遍历数组,为每个元素调用指定的函数。

var a = [1,2,3,4,5]; 
var sum = 0; 
a.forEach(function (value) {
sum += value
}) 
console.log(sum); //sum = 15

12、map()方法

和forEach()类似,调用数组的每个元素传递给指定函数,并返回一个数组,所以它和forEach()的区别在于,有一个返回值。不修改原数组,返回的数组长度和原数组相同

var a = [1,2,3,4,5]; 
var b = a.map(function (value) {
return value+1
}) 
console.log(b); //返回[2,3,4,5,6]

13、filter()方法,返回的是调用数组的一个子集

var a = [1,2,3,4,5]; 
var b = a.filter(function (value) {
return value > 3
}) 
console.log(b); //返回[4,5]
注意:如果使用map()方法,返回的是[false, false, false, true, true]

filter()会跳过稀疏数组中缺少的元素,他的返回数组总是稠密的。所以可以用一下方法来压缩稀疏数组的空缺。

var a = [1,2,,,5]; 
var b = a.filter(function (value) {
return true
}) 
console.log(b); //返回[1,2,5]

14、every()和some()

every()方法是只有数组中所以元素都满足某个条件才会返回true;some()方法是只要有满足条件的值,就返回true。
以every()方法为例

var a = [1,2,3,4,5];
a.every(function (value) {
return value < 10
}) //true 
a.every(function (value) {
return value % 2 === 0
}) //false

15、indexOf()和lastIndexOf()

这两个方法都是用来搜索整个数组中具有给定值的元素,返回找到的第一个元素的索引,如果没找到,则返回-1。

区别在于indexOf()从头至尾搜索,而后者则是反向搜索。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript中对Attr(dom中属性)的操作示例讲解
Dec 02 Javascript
原生javascript实现无间缝滚动示例
Jan 28 Javascript
jquery.mobile 共同布局遇到的问题小结
Feb 10 Javascript
JavaScript获取DOM元素的11种方法总结
Apr 25 Javascript
利用yarn实现一个webpack+react种子
Oct 25 Javascript
JavaScript字符串对象
Jan 14 Javascript
vue-router 中router-view不能渲染的解决方法
May 23 Javascript
jquery append与appendTo方法比较
May 24 jQuery
使用electron制作满屏心特效的示例代码
Nov 27 Javascript
js实现时分秒倒计时
Dec 03 Javascript
ant design 日期格式化的实现
Oct 27 Javascript
cypress测试本地web应用
Jun 01 Javascript
送你43道JS面试题(收藏)
Jun 17 #Javascript
通过实例学习React中事件节流防抖
Jun 17 #Javascript
如何解决js函数防抖、节流出现的问题
Jun 17 #Javascript
使用imba.io框架得到比 vue 快50倍的性能基准
Jun 17 #Javascript
通过js给网页加上水印背景实例
Jun 17 #Javascript
JavaScript 扩展运算符用法实例小结【基于ES6】
Jun 17 #Javascript
通过实例解析js简易模块加载器
Jun 17 #Javascript
You might like
Ajax+PHP边学边练 之五 图片处理
2009/12/03 PHP
php echo 输出字符串函数详解
2010/05/13 PHP
php.ini中date.timezone设置分析
2011/07/29 PHP
php中的一些数组排序方法分享
2012/07/20 PHP
php使用ICQ网关发送手机短信
2013/10/30 PHP
学习php设计模式 php实现享元模式(flyweight)
2015/12/07 PHP
laravel5.5添加echarts实现画图功能的方法
2019/10/09 PHP
用js实现的页面关键字密度查询代码
2007/12/27 Javascript
jquery调取json数据实现省市级联的方法
2015/01/29 Javascript
JS获取iframe中marginHeight和marginWidth属性的方法
2015/04/01 Javascript
javascript常用方法总结
2015/05/14 Javascript
Bootstrap按钮功能之查询按钮和重置按钮
2016/10/26 Javascript
使用JavaScript获取URL中的参数(两种方法)
2016/11/16 Javascript
利用d3.js力导布局绘制资源拓扑图实例教程
2019/01/08 Javascript
webpack-url-loader 解决项目中图片打包路径问题
2019/02/15 Javascript
vue 详情跳转至列表页实现列表页缓存
2019/03/27 Javascript
python编程开发之textwrap文本样式处理技巧
2015/11/13 Python
Python进行数据提取的方法总结
2016/08/22 Python
转换科学计数法的数值字符串为decimal类型的方法
2018/07/16 Python
python将字符串以utf-8格式保存在txt文件中的方法
2018/10/30 Python
python中append实例用法总结
2019/07/30 Python
python中open函数的基本用法示例
2019/09/07 Python
python 利用zmail库发送邮件
2020/09/11 Python
python 通过pip freeze、dowload打离线包及自动安装的过程详解(适用于保密的离线环境
2020/12/14 Python
美国面料纺织品商城:Fabric.com
2017/06/28 全球购物
美国饼干礼物和美食甜点购买网站:Cheryl’s
2020/05/28 全球购物
计算机专业学生求职信分享
2013/12/15 职场文书
学生个人自我鉴定范文
2014/03/28 职场文书
《郑和远航》教学反思
2014/04/16 职场文书
中共广东省委常委会党的群众路线教育实践活动整改方案
2014/09/23 职场文书
运动会广播稿200字
2014/10/18 职场文书
舞出我人生观后感
2015/06/16 职场文书
安全生产隐患排查制度
2015/08/05 职场文书
优质服务心得体会(共4篇)
2016/01/22 职场文书
2016五四青年节活动总结范文
2016/04/06 职场文书
TV动画《史上最强大魔王转生为村民A》番宣CM公布
2022/04/01 日漫