Backbone: How to trigger methods in a parent view

2019-07-04 02:00发布

I have an alphabet filter view (a, b, c, d etc) that a lot of views will be using. I have setup a method on the main view to fetch results from the API using the letter clicked.

I've setup this by passing a callback function down to the alphabet filter as per below:

view = new App.Views.Common.AlphabetFiltersIndexView(filterCallback: @paginationFilter)
@$(".pagination-vertical").replaceWith(view.render().el)

Calling the filterCallback and passing arguments works, however the paginationFilter method called now belongs to the Alphabet Filters.

Question: How do I call a parent view's method and keep the method's relationship with the original top view?

3条回答
forever°为你锁心
2楼-- · 2019-07-04 02:25

You could go about this two ways:

  1. Pass the parent view to your child view, OR have your child view find its parent via a global object, if you're using one. Call the parent view's function from the child

  2. You could have your child view raise an event when you need the parent view's function to be called. Your parent view should be listening for this event from your child view, and respond by calling the method required.

查看更多
唯我独甜
3楼-- · 2019-07-04 02:27

You can use the following Underscore call in your AlphabetFiltersIndexView in it'sinitialize method

_.bindAll(callBackContext, "YourCallBack");

This will ensure the callback is bound to the object of your choice (The parent view).

You can pass in the values of callBackContext and "YourCallBack" as parameters to the AlphabetFiltersIndexView, which you can then control based on the context of the parent view.

查看更多
欢心
4楼-- · 2019-07-04 02:41

You should trigger an event in the child view using something like

this.trigger('event', [args]);

and listen to it from the parent view

this.listenTo(childView, 'event', this.paginationFilter);

(Recommend giving the event a proper name. Consider a name such as 'page:change'. 'page' is a sort of namespace just to make the events in large application easier to name and organize. There is no real namespace functionality.)

查看更多
登录 后发表回答