最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - jQuery - $(document).off() - Stack Overflow

programmeradmin1浏览0评论

I have a site that is entirely driven by ajax. Once the page loads, the page never re-loads entirely unless it is refreshed. I have a few different apps running on this site and I am using .on() to add event handlers at the document level, but these should only be applied when a certain application is being used on the site. In order to avoid saturating the site with unnecessary event handlers, im wondering if there are any side-effects of using $(document).off() when the user switches applications. This should clear all of the events I bound before attaching new ones. I just want to make sure im not un-binding something I dont know about.

I have a site that is entirely driven by ajax. Once the page loads, the page never re-loads entirely unless it is refreshed. I have a few different apps running on this site and I am using .on() to add event handlers at the document level, but these should only be applied when a certain application is being used on the site. In order to avoid saturating the site with unnecessary event handlers, im wondering if there are any side-effects of using $(document).off() when the user switches applications. This should clear all of the events I bound before attaching new ones. I just want to make sure im not un-binding something I dont know about.

Share Improve this question asked Aug 15, 2015 at 13:45 Kirk LoganKirk Logan 7832 gold badges9 silver badges24 bronze badges 4
  • no way for us to know what you can or can't unbind in your app ... it's your code and we can't see any of it – charlietfl Commented Aug 15, 2015 at 13:48
  • To clarify, I want to unbind absolutely everything that I bound. I just want to be sure that im not unbinding something that jQuery binds to the document when it initializes. – Kirk Logan Commented Aug 15, 2015 at 13:50
  • Won't affect anything within jQuery core. Any plugins you use would need to be assessed individually though – charlietfl Commented Aug 15, 2015 at 13:52
  • Understood, thanks for the quick response – Kirk Logan Commented Aug 15, 2015 at 13:52
Add a ment  | 

1 Answer 1

Reset to default 3

You can use jQuery event namespaces. To add events to $(document) use the application name as namespace, and then remove all of them using the same namespace.

For example, if you you've application named "appA", and you want to add event listeners for a series of events:

$(document).on('resize.appA', function() { });
$(document).on('anotherEvent1.appA', function() { });
$(document).on('anotherEvent2.appA', function() { });

Now to remove all application event on document just use:

$(document).off('.appA');

btw - this will work only on events directly added to document, and not to any children. If you want to affect children as well, bind the events to $(document), and use event delegation to affect the children. In this way, you can remove all app events at once.

发布评论

评论列表(0)

  1. 暂无评论