这些是我在循环时用来声明jquery对象的一些基本方法:

let $divs = $('.mydiv');

for (let i = 0; i < $divs.length; i++) {
    let $div = $($divs[i]);
}

// or

for (let $div of Array.from($divs)) {
    $div = $($div);
}

// or

Array.from($divs).forEach(function ($div) {
    $div = $($div);
});


我想保存$div = $($div)行(以便更快地编写代码),如下所示:

for (let $($div) of Array.from($divs)) {
    // ...
}

// or

Array.from($divs).forEach(function ($div = $($div)) {
    // ...
});


有没有办法实现我的目标?

更新:

由于$('.mydiv')可以返回1个以上的元素,因此我需要一个循环才能使用它们。但是使用循环,它不会为每个元素返回一个jquery对象,我必须用$(...)包装它

最佳答案

不是真正的答案,不是真正的问题

在具有$包装的元素数组之后,您打算如何处理?



$('.mydiv')                        // = $-wrapped html collection
  .map((_, e) => $(e))             // = array of $-wrapped elements
  .each((_, e) => console.log(e))  // = log each $-wrapped element

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<div class="mydiv">1</div>
<div class="mydiv">2</div>
<div class="mydiv">3</div>





确实与下面的脚本没有什么不同,那又有什么意义呢?



$('.mydiv')                          // = $-wrapped html collection
  .each((_, e) => console.log($(e))) // = log each $-wrapped element

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<div class="mydiv">1</div>
<div class="mydiv">2</div>
<div class="mydiv">3</div>

10-07 19:28
查看更多