1

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>
4

2 に答える 2

2

これviewは、最新のコミットで変更されたルックアップ コンテキストが原因です。viewでプロパティを検索する場合は、先頭に追加する必要がありviewます。コミット8a6c6のドキュメントの更新を参照してください。

したがって、テンプレートは次のように変更されます

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

http://jsfiddle.net/pangratz666/DsdHU/を参照してください。

Tom Dale には、変更点をさらに説明するGistがあります。

于 2012-06-21T05:46:49.967 に答える
0

latest-ember.js (および ember-1.0.pre.js) にはハンドルバーが含まれなくなりました。独自に含める必要があります。

また、イベントループを自分で開始する必要があります: !! ->もう必要ないようです.. !!

App.initialize();

..関連する jsfiddle: http://jsfiddle.net/aGMzD/

于 2012-09-19T07:49:24.273 に答える