gpt4 book ai didi

jquery - 将 jquery 选择器传递给函数

转载 作者:行者123 更新时间:2023-12-01 00:45:17 24 4
gpt4 key购买 nike

您好,这可能是一个简单的愚蠢问题,但是我如何将 jquery 选择器传递给函数?

我正在这样做,但它不起作用。提前致谢!

var $list=$('#startlist')
var $container=$list.parent();
var $containerTop=$('#toprow');
var $containerTwo=$('#etrow #bottomrow');

var $li=$list.find('li');

var totHt=0;
var totItems=$li.length;
var listCount = 0;
$li.each(function( idx){

var ht=$(this).outerHeight(true);

if( totHt + ht >= maxHt || totHt + ht + 10 >=maxHt || idx==totItems-1){
if (listCount>=3 && listCount < 6)
createNewList($containerTop);
else if (listCount >=6)
createNewList($containerTwo);
else
createNewList($container);
totHt=0;
listCount++;
}else{
totHt += ht;
}

});

function createNewList ($cont)
{
$('<ul>').append( $(this).prevAll().andSelf() ).appendTo( $cont );

}

我收到此错误:

Uncaught Error: NOT_FOUND_ERR: DOM Exception 8

如果我用它替换 if block ,它可以正常工作:

if (listCount>=3 && listCount < 6)
$('<ul>').append( $(this).prevAll().andSelf() ).appendTo( $containerTop);
else if (listCount >=6)
$('<ul>').append( $(this).prevAll().andSelf() ).appendTo($containerTwo);
else
$('<ul>').append( $(this).prevAll().andSelf() ).appendTo($container);

最佳答案

由于您在 .each 之外定义函数,因此它会丢失上下文。尝试使用 .call 将上下文正确设置为您期望的内容。

createNewList.call(this,$containerTop)

关于jquery - 将 jquery 选择器传递给函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13234955/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com