I'm developping a web app with CodeIgniter on back-end and Backbone.js on front-end. I'm also using HTML5 Boilerplate as my start template.
I'm using Backbone's Controller and History as main navigation through my application. I've done it one time in the past and everything have work fine. The problem is, when i start hashchange event capture with Backbone.History.start() and click on a link example/#home, the hash change in the url, the event is fired but 2 seconds after, the hash is cleared from url and an javascript error is throw only in ie7.
I've take a look at source code and hashchange event is acheived in IE7 by creating an IFRAME running an interval to check hash value change.
Anyone had this weird bug before and know how to solve this?
I'm developping a web app with CodeIgniter on back-end and Backbone.js on front-end. I'm also using HTML5 Boilerplate as my start template.
I'm using Backbone's Controller and History as main navigation through my application. I've done it one time in the past and everything have work fine. The problem is, when i start hashchange event capture with Backbone.History.start() and click on a link example./#home, the hash change in the url, the event is fired but 2 seconds after, the hash is cleared from url and an javascript error is throw only in ie7.
I've take a look at source code and hashchange event is acheived in IE7 by creating an IFRAME running an interval to check hash value change.
Anyone had this weird bug before and know how to solve this?
Share Improve this question edited Mar 31, 2014 at 9:10 BenMorel 36.6k51 gold badges205 silver badges335 bronze badges asked Feb 11, 2011 at 20:52 Dominic MercierDominic Mercier 8082 gold badges9 silver badges17 bronze badges4 Answers
Reset to default 4The right way to handle an #hash base application with Backbone seems to Backbone.history.saveLocation( hash ) and after Backbone.history.loadUrl() to enable Controller's routing.
Whish i knew this before... Have fun with this awesome MVC library :)
The solution that I found to work was to use Ben Alman's hashchange plugin. Go to the start function in Backbone.History and replace the code of the start function with this.
start : function() { $(window).hashchange(this.checkUrl); return this.loadUrl(); }
And be sure to include the hashchange plugin file in your code.
Clicking on a hash-URL does not actually save a history entry in IE -- use Backbone's saveLocation
function to drop a marker of a location you want to be able to go back to. For the full scoop, see:
http://documentcloud.github./backbone/#Controller-saveLocation
I found a solution for this problem from Jon Leighton in the offical issue list: https://github./documentcloud/backbone/issues/228
Until an offical patch add this to the backbone.js (line 689 in Backbone 0.3.3)
this.iframe.document.open().close(); this.iframe.location.hash = window.location.hash;
after the following line:
this.iframe = $('iframe src="javascript:0" tabindex="-1" ').hide().appendTo('body')[0].contentWindow;
(I couldn´t write the plete i-frame tag < & /> - it isn´t allowed here :))