栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

使div可见时的jQuery事件触发动作

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使div可见时的jQuery事件触发动作

您总是可以添加到原始的.show()方法中,这样您就不必在每次显示某些东西或需要它与遗留代码一起使用时都触发事件:

jQuery扩展:

jQuery(function($) {  var _oldShow = $.fn.show;  $.fn.show = function(speed, oldCallback) {    return $(this).each(function() {      var obj         = $(this),          newCallback = function() { if ($.isFunction(oldCallback)) {   oldCallback.apply(obj); } obj.trigger('afterShow');          };      // you can trigger a before show if you want      obj.trigger('beforeShow');      // now use the old function to show the element passing the new callback      _oldShow.apply(obj, [speed, newCallback]);    });  }});

用法示例:

jQuery(function($) {  $('#test')    .bind('beforeShow', function() {      alert('beforeShow');    })     .bind('afterShow', function() {      alert('afterShow');    })    .show(1000, function() {      alert('in show callback');    })    .show();});

这有效地使您可以在仍然执行原始.show()方法的正常行为的同时执行beforeShow和afterShow操作。

您也可以创建另一个方法,这样就不必覆盖原始的.show()方法。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/411356.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号