Backbone routes without hashes?

后端 未结 2 1638
暗喜
暗喜 2020-12-04 12:04

I\'m using backbone for a current project. I was wondering if it\'s possible to do routing without hashes #, like davis.js does.

Thanks!

相关标签:
2条回答
  • 2020-12-04 12:38

    Backbone Boilerplate has an excellent helper that enables pushstate. I use it when there are times I want to bypass 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's 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's internal `navigate` method
        // calls this anyways.  The fragment is sliced from the root.
        Backbone.history.navigate(href.attr, true);
      }
    });
    
    0 讨论(0)
  • 2020-12-04 12:40

    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 don't will fall back to the hash method. There is no real way around this, you can enable for modern browser and fall back or just use hashes for all browsers.

    0 讨论(0)
提交回复
热议问题