Я пытался создать простой список с добавлением виджета в качестве компонента Emberjs.Общее состояние в компоненте Ember
Ниже приведен код, который я использовал:
HTML:
<!DOCTYPE html>
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
<script src="http://cdnjs.cloudflare.com/ajax/libs/handlebars.js/1.0.0/handlebars.js"></script>
<script src="http://cdnjs.cloudflare.com/ajax/libs/ember.js/1.0.0/ember.min.js"></script>
<meta charset=utf-8 />
<title>Ember Component example</title>
</head>
<body>
<script type="text/x-handlebars" id="components/appendable-list">
<h2> An appendable list </h2>
<ul>
{{#each item in myList}}
<li> {{item}} </li>
{{/each}}
</ul>
{{input type="text" value=newItem}}
<button {{action 'append'}}> Append Item </button>
</script>
<script type="text/x-handlebars">
{{appendable-list}}
{{appendable-list}}
</script>
</body>
</html>
Javascript:
App = Ember.Application.create();
App.AppendableListComponent = Ember.Component.extend({
theList: Ember.ArrayProxy.create({ content: [] }),
actions: {
appendItem: function(){
var newItem = this.get('newItem');
this.get('theList').pushObject(newItem);
}
}
});
В этом случае список разделяется между двумя экземплярами (то есть, добавление в одно дополнение к другому)
Вот JsBin, чтобы проверить это: http://jsbin.com/arACoqa/7/edit?html,js,output
Если я делаю следующее, это работает:
window.App = Ember.Application.create();
App.AppendableListComponent = Ember.Component.extend({
didInsertElement: function(){
this.set('myList', Ember.ArrayProxy.create({content: []}));
},
actions: {
append: function(){
var newItem = this.get('newItem');
this.get('myList').pushObject(newItem);
}
}
});
Вот JsBin: http://jsbin.com/arACoqa/8/edit?html,js,output
Что я делаю неправильно? Заранее спасибо!
Отлично! Я думаю, что ваш путь намного чище. Спасибо! – tcbpg
Упс! Я мог бы поклясться. Надеюсь, он исправлен. – tcbpg