jquery map调用get()方法的困惑

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jquery map调用get()方法的困惑相关的知识,希望对你有一定的参考价值。

$( "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>

这是我从官网拿出来的一个example

本人曾经很困惑,不明白为什么在map方法的后面要在调用一个get方法。按照理论来说,map 返回出来的数据应该一个数组(集合)。 可以直接调用join方法转化为string.


仔细阅读文档后发现这里有文章。


我原来混淆的javascript object/array(其实就是dom) 和jqeruy object/ array这两个概念

其实javascript的对象和数组和jquery的是相互不能识别的。 

当我发现了这个”秘密“之后,就大概明白为什么需要get 方法了


.get(): Retrieve the DOM elements matched by the jQuery object.

这是官网的定义。就是把jquery 对象转为dom 对象。 所有的dom对象都是可以被javascript所使用的。这里jquery其实就是通过get这个机制来顺利过渡两者。


所以我们回头看上面这个例子 

map 返回了jquery array 然后通过get方法转为javascript dom array。 最后调用join方法变为string.


本文出自 “Development” 博客,请务必保留此出处http://jamesdev.blog.51cto.com/2066624/1774930

以上是关于jquery map调用get()方法的困惑的主要内容,如果未能解决你的问题,请参考以下文章

jquery---调用静态方法-each--map-数组与伪数组的差别

通过 GET 方法调用 WCF jQuery AJAX 中的安全问题

为啥这个对 C# 方法的 jquery ajax GET 调用不起作用?

map方法,以及filter方法的使用

JQuery的getpostajax方法

map.get() 方法不适用于 D3 v6