Старайтесь избегать прямого манипулирования DOM, когда вы можете использовать Vue. В этом случае лучшим вариантом будет установить текущие активные данные в любой список, который вы хотите отобразить. Затем в шаблоне выполните цикл по каждому из этих активных элементов данных.
new Vue({
el: "#app",
data: {
reportData: [{
text: 'Item 1 Text',
value: 'Item 1 Value'
}, {
text: 'Item 2 Text',
value: 'Item 2 Value'
}, {
text: 'Item 3 Text',
value: 'Item 3 Value'
}],
}
})
<link type="text/css" rel="stylesheet" href="https://unpkg.com/bootstrap/dist/css/bootstrap.min.css" />
<link type="text/css" rel="stylesheet" href="https://unpkg.com/bootstrap-vue@latest/dist/bootstrap-vue.css" />
<script src="https://unpkg.com/vue"></script>
<script src="https://unpkg.com/bootstrap-vue@latest/dist/bootstrap-vue.js"></script>
<div id="app">
<section class="drop-down">
<b-dropdown text="Error Reports" class="m-md-2">
<b-dropdown-item v-for="(item, key) in reportData" :key="key">
{{ item.text }}: {{ item.value }}
</b-dropdown-item>
</b-dropdown>
</section>
</div>
Не стесняйтесь, дайте мне знать, если у вас есть какие-либо вопросы.
Редактировать:
Следующий примерможет помочь прояснить, что вам нужно делать, если у вас есть вложенные массивы объектов, структура которых заранее известна.
Однако, если вы не знаете глубину своего дерева, вам, возможно, придется подуматьиспользуя рекурсивные компоненты .
new Vue({
el: "#app",
data: {
// This is your input data
dataStore: [{
name: 'Item 1',
value: [{
text: 'SubItem 1 Text',
value: 'SubItem 1 Value'
}, {
text: 'SubItem 2 Text',
value: 'SubItem 2 Value'
}, {
text: 'SubItem 3 Text',
value: 'SubItem 3 Value'
}]
}, {
name: 'Item 2',
value: [{
text: 'SubItem 1 Text',
value: 'SubItem 1 Value'
}, {
text: 'SubItem 2 Text',
value: 'SubItem 2 Value'
}, {
text: 'SubItem 3 Text',
value: 'SubItem 3 Value'
}, {
text: 'SubItem 4 Text',
value: 'SubItem 4 Value'
}, {
text: 'SubItem 5 Text',
value: 'SubItem 5 Value'
}, ]
}],
// This is the data we will display
activeData: null
},
created() {
// The value that will be selected upon creation
this.activeData = this.dataStore[0]
},
methods: {
changeData() {
this.activeData = this.dataStore[1]
}
}
})
<link type="text/css" rel="stylesheet" href="https://unpkg.com/bootstrap/dist/css/bootstrap.min.css" />
<link type="text/css" rel="stylesheet" href="https://unpkg.com/bootstrap-vue@latest/dist/bootstrap-vue.css" />
<script src="https://unpkg.com/vue"></script>
<script src="https://unpkg.com/bootstrap-vue@latest/dist/bootstrap-vue.js"></script>
<div id="app">
<section v-if="activeData" class="drop-down">
<h2>{{ activeData.name }}</h2>
<b-dropdown text="Error Reports" class="m-md-2">
<b-dropdown-item v-for="(item, key) in activeData.value" :key="key">
{{ item.text }}: {{ item.value }}
</b-dropdown-item>
</b-dropdown>
</section>
<button @click="changeData">Change Data Item</button>
</div>