我在.vue文件中有一個<filter>
組件,它具有一些控制查詢過濾器的屬性。VueJS - 動態重複組件
這個<filter>
可以根據用戶需要隨時添加/刪除。它的行爲與Google Analytics細分過濾器或WordPress的高級自定義字段非常相似。
我看到的唯一解決方案是動態實例化這個組件,並在我的主app
中迭代這些組件的數組,但我並不完全知道該怎麼做。
Vue.component("my-filter", {
template: "#filterTemplate",
data: function() {
return {
field: null,
value: null
}
},
mounted: function() {
this.$emit("filter-created", this);
},
methods: {
\t removeFilter: function() {
\t console.log("Remove this filter");
}
}
});
var app = new Vue({
el: "#app",
data: {
filtersCount: 5,
filters: [] // PROBLEM! I can't decrement on my filtersCount and remove the correct filter. Iteration should be over my "filtersCount" property.
},
methods: {
filterCreated: function(filterObj) {
\t \t \t this.filters.push(filterObj);
},
addFilter: function() {
\t this.filtersCount += 1;
}
}
});
* {
font-family: "Helvetica", "mono";
font-size: 16px;
}
.filterContainer + .filterContainer {
margin-top: 10px;
}
.filterContainer {
display: block;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.3.3/vue.min.js"></script>
<div id="app">
<!-- I shouldn't iterate over an integer value, but over an array of objects to remove the right ones -->
<my-filter v-on:filter-created="filterCreated" v-for="(index, filter) in filtersCount" :key="index"></my-filter>
<br>
<button @click="addFilter">Add filter</button>
</div>
<script type="text/x-template" id="filterTemplate">
<div class="filterContainer">
<input type="text" :value="field" placeholder="Field" />
<input type="text" :value="value" placeholder="Value" />
<button @click="removeFilter">Remove filter</button>
</div>
</script>
你可以添加你所擁有的代碼,那麼遠? –
你好亞當。我其實沒有任何與我的主應用程序相關的代碼。我只有我的組件的代碼,但我不相信它會對問題有用,對不起。如果你能給我一些關於如何去做的理論...... – juniorgarcia
你可以把一些簡單的例子放在一起嗎? 「如果我有這些,我想補充一點,那麼我應該得到這樣的」那種東西? –