Ошибка CollectionView в текущем ember-последнем?

Я сделал несколько тестов с ember-0.9.8.1.js, и следующий код работает, как и ожидалось. После этого я прочитал про роутер и что роутер - код доступен только в актуальном ember-latest.js (16.06.2012). Я тестирую код ниже с этой версией. Проблема в том, что список отображается:

  <div id="ember143" class="ember-view">
    <ul id="PersonList" class="ember-view ListBox">
      <li id="ember179" class="ember-view">
       <script id="metamorph-0-start" type="text/x-placeholder"></script>
       <script id="metamorph-0-end" type="text/x-placeholder"></script>
      </li>
      <li id="ember183" class="ember-view">
        <script id="metamorph-1-start" type="text/x-placeholder"></script>
        <script id="metamorph-1-end" type="text/x-placeholder"></script>
      </li>
      <li id="ember187" class="ember-view">
        <script id="metamorph-2-start" type="text/x-placeholder"></script>
        <script id="metamorph-2-end" type="text/x-placeholder"></script>
      </li>
      <li id="ember191" class="ember-view">
        <script id="metamorph-3-start" type="text/x-placeholder"></script>
        <script id="metamorph-3-end" type="text/x-placeholder"></script>
      </li>
      </ul>
     </div>

но пусто. Что-то с

шаблон: Ember.Handlebars.compile("{{content.name}}"),

работает неправильно или изменились некоторые аспекты синтаксиса.

Строка кода

console.log("content:",this.get('content'));

в обработчике кликов видно, что нужный контент есть, но

Ember.Handlebars.compile("{{content.name}}"),

не будет отображать содержимое.

Это баг???

Javascript-код:

 var App = Em.Application.create({

    ready: function(){
        App.personListController.getData();
    }
    });


    // Model Objects

    App.Person = Ember.Object.extend({
      name: null,
      myTickets: null,
      selected: false
    });


    // Liste von Personen anlegen

    App.personListController = Ember.ArrayController.create({

    getData: function(){

        $.get('json/person.json', function(data) {
            var personList = Ember.A([]);
            data.forEach(function(item) {
                var p = App.Person.create({
                    'name': item.name,
                    'myTickets': null,
                    'selected': false
                });
                personList.pushObject(p);
            });
            App.personListController.set('content', personList);
        })
    },
    resetSelection: function(){
        App.personListController.content.forEach(function(item){
            item.set('selected',false);
        })
    },
    selectedPerson: null
    });


    App.PersonList = Ember.CollectionView.extend({
      tagName: 'ul',
      contentBinding: 'App.personListController.content',
      classNames: ['ListBox'],
      mouseenter: function(event){
        console.log("PersonList.content:",this.get('content'));
      },

    itemViewClass: Ember.View.extend({
        template: Ember.Handlebars.compile("{{content.name}}"),
        classNameBindings: ['selected:selected'],
        selectedBinding: 'content.selected',
        click:
            function(event){
                App.personListController.resetSelection() ;
                this.setPath('content.selected',true);
                App.personListController.set('selectedPerson',this.get('content'));
                console.log("ItemViewInfo selected:",this.getPath('content.selected'));
                console.log("content:",this.get('content'));
                //this.set('isSelected',true);
            }
       })
    });

HTML:

 <script type="text/x-handlebars">
   {{#view App.PersonList id="PersonList"}}

   {{/view}}
</script>

person abaumann    schedule 20.06.2012    source источник


Ответы (2)


Это связано с тем, что контекст поиска для view изменился в последних коммитах. Теперь вам нужно добавить view, если вы хотите найти свойство в view. См. обновления документации в коммите 8a6c6.

Таким образом, шаблон меняется на

template: Ember.Handlebars.compile("{{view.content.name}}")

см. http://jsfiddle.net/pangratz666/DsdHU/.

У Тома Дейла есть Gist, в котором подробно объясняются изменения.

person pangratz    schedule 21.06.2012

Последний-ember.js (как и ember-1.0.pre.js) больше не включает руль, вы должны включить его самостоятельно.

Вы также должны запустить цикл обработки событий самостоятельно: !! -> кажется, что вам это больше не нужно.. !!

App.initialize();

.. связанный jsfiddle: http://jsfiddle.net/aGMzD/

person Ajuhzee    schedule 19.09.2012