jQuery.map( array, callback(elementOfArray, indexInArray) )返回: Array
描述: 将一个数组中的所有元素转换到另一个数组中。
-
添加的版本: 1.0jQuery.map( array, callback(elementOfArray, indexInArray) )
-
添加的版本: 1.6jQuery.map( arrayOrObject, callback( value, indexOrKey ) )
-
arrayOrObject类型: Array,Object待转换数组或对象。
-
callback( value, indexOrKey )类型: Function()处理每一个元素的函数。第一个参数是数组中元素或对象的值,第二个参数是该元素在数组中的索引值或该对象的键。该函数可以返回任何值,该返回值会被添加到数组中。若返回是数组,则会将该数组中的元素添加到最终的结果数组中。在函数内部,
this
指的是全球(window)的对象。
-
如果你希望处理一个jQuery对象——例如,$('div').map( callback );
— 使用 .map() 代替.
$.map()
方法会在数组的每一个元素或对象上应用一个函数并将结果映射到一个新的数组中。在jQuery 1.6之前,,$.map()
只支持遍历数组和类似数组的对象 。在jQuery 1.6也支持遍历对象。
类似数组的对象- 那些有一个.length
属性和一个.length - 1
的所引值-
必须被转换为实际的数组,然后被传递到$.map()
。
jQuery库提供$.makeArray() 这样的转换。
1
2
3
4
5
6
7
8
9
10
|
|
在该方法中提供的转换函数会应用在数组或对象的顶级(top-level)元素上,并且该转换函数中有两个参数:元素在数组或对象中的值及该值所对应的索引值或键。
该函数可以返回:
- 转换后的值,该值会被映射到最终的结果数组中
-
null
或者undefined
, 用于移除该元素 - 数组,会将该数组中的元素添加到最终的结果数组中
例子:
Example: 使用$.map() 修改一个数组的值。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
|
Demo:
Example: 将原始数组中的每个值加 4 后,映射到新的数组中。
1
2
3
|
|
Result:
1
|
|
Example: 若原始数组中的值大于 0,则将该值加 1 后,映射到新的数组中,否则在结果数组中将不包含该值。
1
2
3
|
|
Result:
1
|
|
Example: 将原始数组中每个值及该值加 1 后的值作为返回结果,映射到新生成的数组中。
1
2
3
|
|
Result:
1
|
|
Example: 将原始对象中的每个值乘 2 后,映射到新生成的数组中。
1
2
3
4
|
|
Result:
1
|
|
Example: 将对象中的键映射到新生成的数组中。
1
2
3
4
|
|
Result:
1
|
|
Example: 将原始数组中每个值的两次方作为返回结果,映射到新生成的数组中。
1
2
3
|
|
Result:
1
|
|
Example: 在处理函数中,通过返回 null 的方式来移除该元素。移除条件是该值小于 50。同时将未被移除的元素值减小 45。
1
2
3
|
|
Result:
1
|
|
Example: 通过在处理函数中返回数组的方式,在最终返回的结果数组中添加元素。
1
2
3
4
|
|
Result:
1
|
|