В следующем коде, когда родительским шаблоном является text/x-template
, как показано ниже, дочерний компонент (внутри родителя) будет обработан :
<script type="text/x-template id="#list">
<div class="wrapper">
<p>{{firstName}} -
<button @click="changeFirstName">Change</button>
</p>
<LastNameCmp></LastNameCmp>
</div>
</script>
однако, как показано ниже, если шаблон родителя получен из html, дочерние компоненты не отображаются. Почему это происходит?
шаблон
<div id="app">
<div class="wrapper">
<p>{{firstName}} -
<button @click="changeFirstName">Change</button>
</p>
<LastNameCmp></LastNameCmp>
</div>
</div>
<script type="text/x-template" id="item">
<div><p>{{lastName}} - <button @click="changeLastName">Change</button></p></div>
</script>
VueJS
var LastNameCmp = {
template: '#item',
data() {
return {
lastName: 'Sharma'
}
},
methods: {
changeLastName: function() {
this.lastName = 'Abrahim'
}
}
}
new Vue({
el: '#app',
components: {
LastNameCmp
},
data: {
firstName: 'Rajat'
},
methods: {
changeFirstName: function() {
this.firstName = 'John'
}
}
})
Спасибо.