温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

jquery not不起作用的解决方法

发布时间:2020-12-30 14:12:15 来源:亿速云 阅读:302 作者:小新 栏目:web开发

这篇文章给大家分享的是有关jquery not不起作用的解决方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

jquery not不起作用的解决办法:首先打开不起作用的代码文件;然后修改jquery代码为“$(document).not(‘#date’).click(function(){...}”即可。

jquery中not方法失效的解决方案

筛选元素时,想从$(document)中直接去掉某一元素,使用$(document).not('#a')是无效的。

但要解决这类问题可以使用其它的方法,举个例子

在模拟下拉列表时,想要实现的效果是点击div,隐藏的列表出现,点击任意的地方下拉列表消失

<div id="date">选择日期</div>
<div id="content" style="display:none;">
<ul>
  <li>2月1日</li>
</ul>
</div>

这个时候直接写

$("#date").click(function(){
  $("#content").slideDown();
});
$(document).click(function(){
  $("#content").slideUp();
});

会出现点击div时下拉列表先出现后消失的情况

解决这种问题大部分人最先想到的是

在设置document的点击事件是去掉元素#date,即

$(document).not(‘#date’).click(function(){
  $("#content").slideUp();
});

但not()在这里并不生效

这时就需要换一种思路

在点击date的一瞬间content的高度变为1px,display变为block

所以

$(document).not(‘#date’).click(function(){
  if($("#content").css('display') == 'block' && $("#content").css('height') != '1px'){
    $("#content").slideUp();
  }
});

就可以达到去掉元素#date的效果

另不想使用slideDown()的话

就必须通过增加一个变量记录下拉列表的开闭状态来达到相同的效果

总之其他的情况也可以通过类似的方式来解决题设的问题

感谢各位的阅读!关于“jquery not不起作用的解决方法”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI