为了账号安全,请及时绑定邮箱和手机立即绑定

使用jQuery delay()和css()

使用jQuery delay()和css()

胡子哥哥 2019-08-31 11:24:09
为什么delay()在这里工作:$('#tipper').mouseout(function() {  $('#tip').delay(800).fadeOut(100);});但这没有延迟:$('#tipper').mouseout(function() {  $('#tip').delay(800).css('display','none');});//编辑 - 这是一个有效的解决方案$('#tipper').mouseleave(function() {  setTimeout( function(){    $('#tip').css('display','none');       },800);});
查看完整描述

3 回答

?
繁星coding

TA贡献1797条经验 获得超4个赞

一个小小的jQuery扩展可以帮助解决这个问题。你可以称之为qcss:


$.fn.extend({

   qcss: function(css) {

      return $(this).queue(function(next) {

         $(this).css(css);

         next();

      });

   }

});

这可以让你写:


$('.an_element')

   .delay(750)

   .qcss({ backgroundColor: 'skyblue' })

   .delay(750)

   .qcss({ backgroundColor: 'springgreen' })

   .delay(750)

   .qcss({ backgroundColor: 'pink' })

   .delay(750)

   .qcss({ backgroundColor: 'slategray' })

这可以是定义链式动画的一种相当优雅的方式。请注意,在这个非常简单的形式中,qcss仅支持包含CSS属性的单个对象参数。(你需要做更多的工作才能支持.qcss('color', 'blue')。)


这是jsfiddle 的一个例子。


查看完整回答
反对 回复 2019-08-31
  • 3 回答
  • 0 关注
  • 588 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信