$( "p" ) .append( $( "input" ).map(function() { return $( this ).val(); }) .get() .join( ", " ) );
<form> <input type="text" name="name" value="John"> <input type="text" name="password" value="password"> <input type="text" name="url" value="http://ejohn.org/"> </form>
这是我从官网拿出来的一个examplejavascript
本人曾经很困惑,不明白为何在map方法的后面要在调用一个get方法。按照理论来讲,map 返回出来的数据应该一个数组(集合)。 能够直接调用join方法转化为string.html
仔细阅读文档后发现这里有文章。java
我原来混淆的javascript object/array(其实就是dom) 和jqeruy object/ array这两个概念jquery
其实javascript的对象和数组和jquery的是相互不能识别的。 数组
当我发现了这个”秘密“以后,就大概明白为何须要get 方法了app
.get(): Retrieve the DOM elements matched by the jQuery object.dom
这是官网的定义。就是把jquery 对象转为dom 对象。 全部的dom对象都是能够被javascript所使用的。这里jquery其实就是经过get这个机制来顺利过渡二者。ide
因此咱们回头看上面这个例子 this
map 返回了jquery array 而后经过get方法转为javascript dom array。 最后调用join方法变为string.url