这些是我在循环时用来声明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>