I am new to the Dojo Toolkit. I'm getting the error
Tried to register widget with id=myButton but that id is already registered
whenever I try to load dojo content twice (meaning I load HTML content through jQuery.Load into a container div). Is there a way of unregistering already registered widgets in dojo? I've seen some examples, but I don't really get them working.
My button:
<button dojoType="dijit.form.Button" id="myButton">button</button>
Based on http://bugs.dojotoolkit.org/ticket/5438, I found a sufficient way of destroying dojo-widgets:
This worked for me:
I think you would be better off removing the id from your button and accessing it using an attach point. You would basically do
<button dojoType="dijit.form.Button" data-dojo-attach-point="myButton">button</button>
then in your code you would access it like
this.myButton....
however im not sure which version of dojo you are using. This will fix any id issues since dojo will assign a unique id to it automatically.If you're looking to unregister specific widgets, you can use their
destroy()
ordestroyRecursive()
methods. The second one destroys any widgets inside the one you are destroying (i.e. calling destroyRecursive on a form widget will also destroy all the form components).In your case, it sounds like your best bet would be to do this before
jQuery.load
-The above code will unregister all widgets in
<containerDiv>
, and preserve their associated DOM Nodes. To destroy the DOM nodes, passfalse
todestroyRecursive
instead.Reference:
http://dojotoolkit.org/api/1.3/dijit/_Widget/destroyRecursive