Trunk routes without hashes?

I am using the framework for the current project. I was wondering if routing can be done without # hashes, as davis.js does.

Thank!

+46
javascript
Sep 05 2018-11-15T00:
source share
2 answers

You need to enable pushState

Backbone.history.start({pushState: true})

http://backbonejs.org/#Router

http://backbonejs.org/#History

Edit: as noted in the comments, this will only work for browsers that support pushState, browsers that do not return to the hash method. There is no real way around this, you can enable it for a modern browser and fall back or just use hashes for all browsers.

+62
Sep 05 '11 at 16:13
source share

The base boiler has an excellent helper that allows pushstate. I use it when there are times when I want to get around my router.

 // Trigger the initial route and enable HTML5 History API support, set the // root folder to '/' by default. Change in app.js. Backbone.history.start({ pushState: true, root: app.root }); // All navigation that is relative should be passed through the navigate // method, to be processed by the router. If the link has a `data-bypass` // attribute, bypass the delegation completely. $(document).on("click", "a[href]:not([data-bypass])", function(evt) { // Get the absolute anchor href. var href = { prop: $(this).prop("href"), attr: $(this).attr("href") }; // Get the absolute root. var root = location.protocol + "//" + location.host + app.root; // Ensure the root is part of the anchor href, meaning it relative. if (href.prop.slice(0, root.length) === root) { // Stop the default event to ensure the link will not cause a page // refresh. evt.preventDefault(); // `Backbone.history.navigate` is sufficient for all Routers and will // trigger the correct events. The Router internal `navigate` method // calls this anyways. The fragment is sliced from the root. Backbone.history.navigate(href.attr, true); } }); 
+9
Dec 04 '12 at 7:18
source share



All Articles