0
現時点ではこの問題を回避することはできません。メインの親コンポーネントは子コンポーネントをレンダリングしていません。ページが読み込まれるとエラーはスローされません。Vue 2 - 子コンポーネントはレンダリングされません
私はこれまでのところ、このコードを持っている:
HTML:
<td class="countries-visible-filter">
<visible-filters>
<show-query-filter :selected ="true" query="all" name="All | "></show-query-filter>
<show-query-filter query="true" name="Visible | "></show-query-filter>
<show-query-filter query="false" name="Hidden"></show-query-filter>
</visible-filters>
親コンポーネント:
Vue.component('visible-filters', {
template: `
<div>
<span v-for="filter in queryFilters"
:class="{'text-muted' : !filter.isSelected}"
@mouseenter="changeClassMouseenter($event)"
@mouseout="changeClassMouseout($event)"
@click="countryTest(filter)"
>
{{filter.name}}
</span>
</div>
`,
methods: {
countryTest(filter) {
this.filters.forEach(singleFilter => {
console.log(singleFilter);
});
Event.$emit('country-filter', filter);
}
},
created() {
console.log(this);
this.queryFilters = this.$children;
},
data() {
return {
queryFilters: []
}
}
});
子コンポーネント:
Vue.component('show-query-filter', {
template: `
<div><slot></slot></div>
`,
props: {
query: '',
selected: false,
name: {required: true}
},
mounted() {
this.isSelected = this.selected;
},
methods: {
changeClassMouseenter(event) {
if(!this.selected)
event.target.classList.remove('text-muted')
},
changeClassMouseout(event) {
if(!this.selected)
event.target.classList.add('text-muted')
}
},
data() {
return {
isSelected: false
}
}
});
ここで何が間違っていますか?
あなたは[スロット](https://vuejs.org/v2/guide/components.html#Content-Distribution-with-Slots)として 'ショークエリ-filter'を使用しています、 'visible-filters'の子としてではありません。 –
私はここで間違いなく失われたと思う:D。スロットタグを削除すると、何も変わりません。 – Sasha
@Sasha 'visible-filters'は' visible-filters'ではなく ' 'を含んでいなければなりません –