• 技术文章 >web前端 >前端问答

    在jquery中有map方法吗

    青灯夜游青灯夜游2022-06-09 17:25:21原创185

    jquery中有map()方法。map()方法用于使用指定回调函数处理数组的每个元素(或对象的每个属性),并将处理结果封装为新数组返回,语法“$.map(数组或对象,回调函数)”。map()方法会为回调函数传入两个参数:第一个参数为当前迭代的元素或属性值,第二个参数为当前迭代项的数组索引或对象属性名;如果回调函数的返回值为null或undefined,则不会被添加到结果数组中。

    本教程操作环境:windows7系统、jquery3.6.0版本、Dell G3电脑。

    jquery中有map()方法。

    在jquery中,map()方法用于使用指定回调回调函数处理数组的每个元素(或对象的每个属性),并将处理结果封装为新数组返回。

    注意:1. 在jQuery 1.6 之前,该函数只支持遍历数组;从 1.6 开始,该函数也支持遍历对象。

    语法格式:

    $.map( object, callback )
    参数描述
    objectArray/Object类型 指定的需要处理的数组或对象。
    callbackFunction类型 指定的处理函数。

    map()会为回调函数传入两个参数:其一是当前迭代的元素或属性值,其二是当前迭代项的数组索引或对象属性名。

    回调函数返回值将作为结果数组中的一个元素,如果返回值为null或undefined,则不会被添加到结果数组中。

    示例:使用$.map() 修改一个数组的值

    <!DOCTYPE html>
    <html>
    	<head>
    		<meta charset="utf-8" />
    		<style>
    			div { color:blue; }
    			p { color:green; margin:0; }
    			span { color:red; }
    		</style>
    		<script src="./js/jquery-3.6.0.min.js"></script>
    	</head>
    	<body>
    
    		<div></div>
    		<p></p>
    		<span></span>
    		<script>
    			$(function() {
    				var arr = ["a", "b", "c", "d", "e"];
    				$("div").text(arr.join(", "));
    				arr = $.map(arr, function(n, i) {
    					return (n.toUpperCase() + i);
    				});
    				$("p").text(arr.join(", "));
    				arr = $.map(arr, function(a) {
    					return a + a;
    				});
    				$("span").text(arr.join(", "));
    			})
    		</script>
    
    	</body>
    </html>

    1.png

    扩展知识

    map方法可以遍历数组,那么可不可以遍历伪数组?那让我们直接看代码吧!




    显然是可以的,和jQuery中的each方法一样看,map方法也可以遍历伪数组

    既然jQuery中的each和map方法都可以遍历数组和伪数组,那么它们之间又有什么区别?

    1、each方法默认的返回值是遍历谁就返回谁

    2、map方法默认的返回值是一个空数组

    1、each方法不支持在回调函数中对遍历的数组进行处理

    2、map方法可以在回调函数中通过return对遍历的数组进行处理,然后生成一个新的数组返回

    可以看到map方法返回的数组是索引加上索引对应的值,所以说map方法是可以通过return对遍历的数组进行处理,然后生成一个新的数组返回


    而each是不支持通过return在回调函数中对遍历的数组进行处理

    【推荐学习:jQuery视频教程web前端视频

    以上就是在jquery中有map方法吗的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:jquery
    上一篇:jquery中有没有eval函数 下一篇:jquery怎么获取除了eq选择的元素
    20期PHP线上班

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• jquery可以绑定事件调用函数吗• jquery怎么计算星期几• json和jquery有什么区别• jquery语法中冒号是啥意思• jquery怎么改变margin的值• jquery怎么求高度
    1/1

    PHP中文网