javascript - 使用backbone.js在同一页面上进行多个 View

标签 javascript jquery backbone.js

我正在通过制作工艺系统来测试主干。你有元素(石头、木头、金子......),你可以用它来制裁剪品。

要制裁剪品,你有一些配方,所以我有两个模型:

Recipe 
Element

在页面底部,我使用主干 View 列出了元素列表。它运作得很好。当您点击某个元素时,我会将其添加到我的包中。

我的根路由器:

class MyTest.Routers.App extends Backbone.Router
   routes:
    '': 'index'
    'elements/:id' : 'show'

   initialize: ->
     @elements = new MyTest.Collections.Elements()
     @elements.fetch()

   index: ->
      view = new MyTest.Views.ElementsIndex(collection: @elements)
      $('#elements').html(view.render().el)
      @initRecipe()

   initRecipe: ->
     @recipes = new MyTest.Collections.Recipes()
     @recipes.fetch()
     view = new MyTest.Views.RecipesIndex(collection: @recipes)
     $('#recipes').html(view.render().el)

   show: (id) ->
      alert "Element #{id}"

我的元素 View :

class MyTest.Views.Element extends Backbone.View

  template: JST['elements/element']

  events:
    'element_rended': 'initImagesDatas'
    'click  img' : 'observeImageEvents'
    'click .more': 'addToBag'
    'click .less': 'decreaseNumber'

  tagName : 'li'

  render: ->
    $(@el).html(@template(element: @model))
    @currentImage = $(@el).find('img')
    @craftBox = null
    $(@el).trigger('element_rended')
    this

  initImagesDatas: ->
    @currentImage.data('alreadyAdded',false)
    @currentImage.data('position',false)

  observeImageEvents: (event) ->
    event.preventDefault()
    $(event.target).parent().next('div.element-description').fadeToggle()

  isAdded: ->
    if (@currentImage.data('alreadyAdded') == true) then true else false

  addToBag: (event) ->
    if (@isAdded())
      @incrementNumber()
    else
      @getNextCraftBox().append(@currentImage.clone())
      @currentImage.data('alreadyAdded',true)
      @incrementNumber()

  getNextCraftBox: ->
    returnItem = $('#craft-area li').eq(0)
    $('#craft-area li').each ->
      if $(this).find('img').length == 0
        returnItem = $(this)
        return false
    @craftBox = returnItem
    return returnItem

  incrementNumber: ->
    @craftBox.find('.number').show()
    @craftBox.find('.number').text(parseInt(@craftBox.find('.number').text())+ 1)

  decreaseNumber: ->
    if parseInt(@craftBox.find('.number').text()) == 1
      @removeToBag()
    else
      @craftBox.find('.number').text(parseInt(@craftBox.find('.number').text())- 1)

  removeToBag: ->
    if (@isAdded())
      @craftBox.parents('ul').append('<li><div class="number">0</div></li>')
      @craftBox.remove()
      @currentImage.data('alreadyAdded',false)

我的食谱 View :

class MyTest.Views.Recipe extends Backbone.View

  recipeSelected: null

  template: JST['recipes/recipe']

  tagName : 'li'
  className: 'recipe-li',

  events:
      'click': 'preFillItemsRequired'

  preFillItemsRequired: ->
    if $(@el).hasClass('selected') then $(@el).removeClass('selected') else $(@el).addClass('selected');
    recipeSelected = @model;
    @addIngredient()

  addIngredient: ->
    console.log('pass')

  render: ->
    $(@el).html(@template(recipe: @model))
    this

我的问题是如何在我的两个 View 之间进行交互?例如,如何从我的元素 View 中获取我选择的配方(不使用 css 选择器)?

我的测试如下:

My interface

最佳答案

最简单且正确的 MVC 方法是让他们观察相同的模型。

View 不应该能够与另一个 View 交互,但它应该能够观察模型并更改模型状态,或者根据模型状态更改自己的状态。

var MyTest.Views.Recipe = Backbone.View.extend({
    initialize: function(){
        this.model.on('change:selected', this.render, this);
    },
    events: {
        'click': function(){
            this.model.set('selected', this.cid);
        }
    },
    render: function(){
        if( this.model.get('selected') == this.cid ) {
            this.$el.addClass('selected')
        }
        else {
            this.$el.removeClass('selected')
        }
    }
});

var model = new Backbone.Model();

var view1 = new MyTest.Views.Recipe({
    model: model,
});

var view2 = new MyTest.Views.Recipe({
    model: model,
})

// ...

关于javascript - 使用backbone.js在同一页面上进行多个 View ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9517234/

相关文章:

javascript - 如何访问 Wikipedia API 返回的 JSON 中的嵌套对象

javascript - 使用 Backbonejs 处理 .NET {d :"data"} JSON 响应

backbone.js - 下划线 - 针对值数组进行过滤

javascript - Backbone.js 刷新 View 而不重新加载页面

javascript - 根据类名获取图像属性

javascript - 如何灰显后退按钮并查看浏览器源代码

javascript - Redis Store 没有 get 方法?

javascript - 在每个 Ember Handlebars 中迭代数组

javascript - 哪种写内容人口的方式更好?

php - Internet Explorer 中的 Ajax 和 JSON 响应错误(适用于所有其他浏览器)