js中的数组

准备写一系列的文章记录做题的同时,与学习到的知识融汇贯通,没事的时候可以拿出来看看。

1.题目:查找数组元素位置

输入:[ 1, 2, 3, 4 ], 3
返回 位置,如果没有找到返回-1

思路:最开始想到的就是for循环之后判断是否有这个数值,这也证明了基础相当的不牢靠,js中有相关的方法indexOf,直接拿arr.indexOf(item)就能直接返回位置。

高程3中(95页),记录了两个方法,indexOf()和lastIndexOf(),他们都是接受两个参数,要查找的数组和查找起点的位置,一个从开始算,一个从最后开始算,没有找到返回-1.题目中是全局查找,所以,第二个参数可以不填(查找起点的位置)。

一个栗子:

var arr = [1,2,3,4,5];

arr.indexOf(2);
arr.indexOf(7)

//返回 1
//返回 -1

 

也可以使用forEach循环来解题。

关于forEach(96页),迭代[dié dài]方法中记录了5个方法。他们都接受两个参数,1需要运行的函数方法,2运行这些函数的作用域对象(表示this指向,个人理解,this指向的当前的作用域,如果没有会向上找),然后就是函数啦。运行的函数方法接受三个参数:1.数组中的所有值(相当于for循环中的【i】每一个数组的值,这样理解),2.数组中的位置,3.数组本身,知道了具体使用方法,看看他们的兄弟,以及他们的方法。

every():简单的说就是对数组进行判断,如果数组中的值与我们设定的条件都满足,那么就会返回true。

栗子:

var arr = [1,2,3,4,5];
var items = arr.every(function(item,index,arr){
   //item表示每一个数组里面的值 
   return item > 2
})
console.log(items)
//返回false  ,因为里面有两个返回false,1 2 都是小于等于2
//如果数组中有一个为空,还是会返回 true
//没有值 [1,2,3,'',5],undefind,'xxx'字符串,设定条件为大于0,就会返回false

 

filter():这个就是把数组中的值进行判断,如果这些值有些返回true的话,那么就返回true的集合(array);通常用来进行过滤。

栗子:

var arr = [1,2,3,4,5];
var items = arr.filter(function(item,index,arr){
   return item > 2 
})

console.log(items)

//返回 [3,4,5]
//数组有空或者没有值,undefined,‘xxx’,就会直接忽略
//如:[1,2,3,,5],[1,2,3,'',5]
//打印返回 [1,2,3,5]

 

forEach():原话是对数组中的每一项运行给定函数,方法没有返回值。简单点,就是这数组的每一个值都会被一个function方法过一遍,function的中方法自定义,返回也自定义,是最自由的一个方法。参考:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach

栗子:

var arr = [1,2,3,4,5];
var num = [];
arr.forEach(function(item,index,arr){
   if(item > 2){
       num.push(item)
   }
})
console.log(num)

//返回 [3,4,5]
// 需要注意的是,它只接受数值,
//undefined,空,或者没有值返回也是不一样的
1,2,3,,5,直接打印返回[1,2,3,5]
1,2,3,'',5 返回 [1,2,3,,5]
1,2,3,undedined,5 返回 [1,2,3,undefined,5]

 

 

map():改方法与forEach差不多,但是它是有返回值的,返回调用方法结果值的数组。

栗子:

var arr = [1,2,3,4,5]
var items = arr.map(function(item,index,arr){
   return item *2
})

console.log(items)

//返回 [2, 4, 6, 8, 10]

//[1,,3,4,5] 返回 [2, undefined × 1, 6, 8, 10]
//[1,'',3,4,5] 返回 [2, 0, 6, 8, 10]
//[1,'xx',3,4,5] 返回 [2, NaN, 6, 8, 10]
//[1,undefined,3,4,5] 返回 [2, NaN, 6, 8, 10]

 

some:():方法同上,只是如果与设定的判断中有一个是true,那么就返回true

栗子:

var arr = [1,2,3,4]
var items = arr.some(function(item,index,arr){
  return item>3
})
console.log(items)

//返回 true
//传啥只要一个返回ture 就返回 true 省心!!!

上面几种遍历数组的方式都不能修改原数组的。需要变量来存储。

其实,在写这些方法的时候,我又想到几个方法来解这个问题。

1.那么先看every方法,pass,只返回true或false,无法拓展

2.fllter,过滤这个方法,是可以不过需要借助indexOf

demo:

//我们传入的值
var num = 1;

var arr = [1,2,3,4,5];
var items = arr.filter(function (item,index,arr) {
    if(item === num){
        console.log(arr.indexOf(num))
        return arr.indexOf(num);
    }else{
        console.log(-1);
        return -1;
    }
})

//返回 0 
//返回 4个 -1
这不是我们希望的结果

修改了一下,参考了别人的代码

var num = 2;
var fa = -1;
var arr = [1,2,3,4,5];
var items = arr.filter(function (item,index,arr) {
    if(item === num && fa === -1){
        fa = index
    }else{
        return -1
    }
    console.log(fa)
})
只返回一个位置,num=2,返回1,跟我们的结果一样。

那么,forEach,map也是同样的可以用这种方法进行判断。

不过还是要用js自带的indexOf方法,不是因为别的,写的太多,不够装逼啊!!!

 

posted @ 2017-08-06 22:49  懒人的懒  阅读(163)  评论(0编辑  收藏  举报