0基础学习微信小程序(12)-ECMAScript5数组操作方法

Posted 面向对象思考

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了0基础学习微信小程序(12)-ECMAScript5数组操作方法相关的知识,希望对你有一定的参考价值。


首先补充说明一下,ECMAScript是欧洲计算机制造商协会(European Computer Manufacturers Association)为了统一各种script,以javascript1.1为基础搞出来的一种脚本语言规范。ECMAScript5是这个规范第五个版本。由于它得到了各大浏览器厂商的响应积极,所以称得上是JavaScript的未来。微信小程序也支持ECMAScript5。


ECMASript5中的数组方法


forEach


forEach方法提供了一种相对简单的(至少是在形式上)方法遍历数组,它有3个参数:数组元素,元素的索引和数组本身。


data = [1, 2, 3, 4, 5];


//所有元素求和

var sum = 0;

data.forEach(funtion(value){sum += value;}) 

sum                                                   //=>15

//每个元素乘2

data.forEach(function(v, i, a){ a[i] = v * 2;});

data               //=>[2, 4, 6, 8, 10]


看懂没有?如果没懂也不要紧,我们以乘2为例,稍微展开说明。代码可能不能执行,只是为了说明。


forEach的实现大致如下,想象的,偏差应该不大。


function forEach(f)

{

    for(int i = 0;  i < array.length; i++)

        f(array[i], i, array);   

}


用户定义一个函数,参数为数组元素,元素的索引和数组本身。之所以这样定义是forEach方法实现的要求。


function mul2(v, i, a)

{

    a[i] = v * 2;

}


接下来是调用


data.forEach(mul2);


这样就好理解多了。示例中只是将定义乘2函数和调用该函数合并成了一行。


map


这个方法和映射没有任何关系,功能是将数组中的每个元素传递给指定的函数进行处理,并将返回值合成一个数组返回。


a = [1, 2, 3];

b = a.map(function(value){ return value * 2}); //=>b = [2, 4, 6]


flter


对数组中的每个元素进行筛选,返回由符合条件的元素构成的数组。


 a = [1, 2, 3, 4, 5, 6, 7]

 b = a.filter(function(x){ return x%2== 0  });  //=>b= [2, 4, 6]


every和some


every方法和some方法对数组进行逻辑判定。


a = [1, 2, 3, 4, 5];

a.every(fuction(x){ return x > 3 }); //=> false.


这个方法对数组的所有元素调用指定的函数,只有所有的(every)结果都为真,every方法的结果才为真,否则结果为假。


a = [1, 2, 3, 4, 5];

a.some(fuction(x){ return x > 3 }); //=> true.


这个方法对数组的所有元素调用指定的函数,只要某些(some)结果为真,some方法的结果就为真,只有所有的结果都为假时,结果才为假。


reduce和reduceRight


reduce方法和reduceRight方法使用指定的函数将数组元素进行合并,生成单个值。


a = [1, 2, 3, 4, 5];

factorial = a.reduce(function(prev, v){ return prev * v });


这是一个计算阶乘的例子。被指定函数的两个参数一个是前一次计算的结果,一个是新的元素值。reduce方法会对所有的元素调用指定函数。实际上除了函数以外,reduce还有另外一个参数,用于指定计算的初始值。如果不指定,则使用数组的第一个元素作为初始值。


reduceRight的功能和reduce类似,只是计算的方向是从后向前。


indexOf和lastIndexOf


indexOf方法搜索数组中的元素,找到第一个具有给定值的元素的索引值,如果没有找到,则返回-1。可以使用可选的第二参数指定检索的开始位置。


lastIndexOf的功能和indexOf类似,只是计算的方向是从后向前。


参考资料


【JavaScript权威指南,机械工业出版社】


写在文章的最后



本日关注数:543 谢谢转发,关注!


以上是关于0基础学习微信小程序(12)-ECMAScript5数组操作方法的主要内容,如果未能解决你的问题,请参考以下文章

微信小程序基础学习

微信小程序

微信小程序入门与实战 常用组件API开发技巧项目实战

微信小程序基础

微信小程序基础

微信小程序来了,整理微信小程序学习教程网站