I'm using JQuery tools' tabs feature and at the same time I use JQuery UI.
If I include both JS libraries, Jquery tools with tabs does not work.
How to fix this conflict? Any help is appreciated.
Thanks in advance.
I'm using JQuery tools' tabs feature and at the same time I use JQuery UI.
If I include both JS libraries, Jquery tools with tabs does not work.
How to fix this conflict? Any help is appreciated.
Thanks in advance.
in my case i change the name of the jquerytools tabs function. from:
to:
so i didn't have to change jquery-ui-tools, this is usefull if you are getting this script from CDN.
You could get a custom jQuery-ui build that that doesn't include the tabs but that might cause some confusion later on. A better approach, IMHO, would be to edit the jQuery-tools
tabs.js
and change this line:to something like this:
I used "fpTabs" for "flowplayer.org tabs", you can use whatever name works for you. That should clear up your conflicts without causing problems anywhere else. Of course, you'd have to remember that you changed
tabs.js
if you ever upgrade but that should be less troublesome than messing around with a tab-lessjquery-ui.js
file.This specific question is about a conflict between the Tabs function in jQueryTools and jQueryUI and not between libraries that both wish to use the "$" and so the noConflict comments are not relevant.
You need to redefine the tabs function (from either library) as one is loaded and before the next is loaded.
First you load your jQuery library and jQueryTools...
Then you redefine the tabs function...
Then you load the jQueryUI library...
Of course, credit to Carl G for this solution, but I thought it was important to draw the distinction between the noConflict solutions that will not work and the loading sequence/redefinition of the tabs function.
You can build your own jquery UI in this url http://jqueryui.com/download
only pick tools you need and do not include component TAB in the options to avoid conflict with jquery tools
There is an easier method. Whenever you use jquery with other libraries (Tools | Prototype | MooTools | etc.) you can use a special noConflict function to re-assign the $ to another variable. For example:
Or you can be more explicit and use jQuery.someFunction() instead of $.someFunction.
Our solution is to include complete jQuery UI and jQuery Tools libraries, but to interject a small javascript fix that renames jQuery UI's
tabs
so that it does not interfere with jQuery Tools (which contains thetabs
feature we use in our site.) We first import jQuery UI, then perform the fixup, and then import jQuery Tools.jquery-ui-jquerytools-tabsconflictfix.js:
It is preferable to set this up so that other programmers are unlikely to accidentally avoid it. We are in an ASP.NET MVC 4 environment, so we create a script bundle that automatically includes the scripts in the correct order:
App_Start\BundleConfig.cs