Preventing full page reload on Backbone pushState

后端 未结 5 985
夕颜
夕颜 2020-12-09 05:21

I\'m trying to prevent full page reloads using Backbone\'s pushState. When I call navigate() from my view\'s event, I see the messages marked // 1 below, but not // 2. In ad

相关标签:
5条回答
  • 2020-12-09 05:48
     $('a').click(function(e){
       e.preventDefault();
       Backbone.history.navigate(e.target.pathname, {trigger: true});
     });
    
    0 讨论(0)
  • 2020-12-09 05:48

    Just a follow up to Derick answer. It worked for me, but to keep it clean, I overwrote the Backbone.View class:

    (coffeescript)

    class NewBackboneView extends Backbone.View
      events:
        'click a' : 'pushstateClick'
    
      pushstateClick: (event) ->
        event.preventDefault()
    
      Backbone.View = NewBackboneView
    

    So every link from my backbone views have the prevent default.

    0 讨论(0)
  • 2020-12-09 05:56

    The answer is actually in here https://stackoverflow.com/a/9331734/985383, if you enable pushState you want links to work and not prevent them as suggested above, or well, is not just preventing them. here it is:

    initializeRouter: function () {
      Backbone.history.start({ pushState: true });
      $(document).on('click', 'a:not([data-bypass])', function (evt) {
    
        var href = $(this).attr('href');
        var protocol = this.protocol + '//';
    
        if (href.slice(protocol.length) !== protocol) {
          evt.preventDefault();
          app.router.navigate(href, true);
        }
      });
    }
    
    0 讨论(0)
  • 2020-12-09 05:59

    to stop the page reload when a user clicks a link, you have to call e.preventDefault() like you were suggesting.

    
    MyView = Backbone.View.extend({
      events: {
        "click .some a": "clicked"
      },
    
      clicked: function(e){
        e.preventDefault();
        // do your stuff here
      }
    });
    

    you're also right that this isn't documented in the backbone docs. events are handled by jQuery, though. so you can assume that any valid jQuery things you would do - such as have an e parameter to an event callback - will work with backbone's events.

    as for this:

    in addition, when I try to open the same tab, the page reloads again.

    are you saying when a user opens a new browser tab to your site's url? if so, then there's nothing you can do about this. when the browser opens the tab it makes the request to the server to load the page.

    if you're referring to a "tab" as part of your site's user interface, though, then the use of e.preventDefault() on your link / "tab" clicks should take care of that.

    0 讨论(0)
  • 2020-12-09 06:02

    It depends on how you've generated the HTML mark-up. It looks like you're using anchor tags (<a>), so if those anchor tag href have values or even an empty string, then you need to cancel the default browser behavior otherwise you'll get a page reload. You can cancel the default behaviour using jQuery're event.preventDefault() like you mentioned. Alternatively, if you're not concerned about progressive enhancement or SEO, then you can set your anchor tag href to # or javascript:void(0);, which will also prevent to the page from reloading. e.g.

    <a href="#">Click me</a>
    

    or

    <a href="javascript:void(0);">Click me</a>
    
    0 讨论(0)
提交回复
热议问题