gpt4 book ai didi

javascript - 如何在 v-for 循环中使用 BootstrapVue - Modal?

转载 作者:行者123 更新时间:2023-11-30 14:58:03 24 4
gpt4 key购买 nike

我正在尝试在 v-for 循环中使用 BootstrapVue - Modal,唯一的问题是模态按钮上的模态指令 ( v-b-modal.modal1 )。 modal1 应该是模态 id 的名称,因为我正在使用循环,所以我在模态中传递索引,例如模态 + 索引,但我不知道如何将按钮指令更改为 v-b-modal-modal1 ... v-b- modal-modal5.

这是模态组件

    <template>
<div>
//This v-b-modal.modal1 should be same as modalId
<b-btn v-b-modal.modal1>Banka: {{ data.offer.client_name }}</b-btn>
<!-- Modal Component -->
<b-modal :id="modalId" title="Oferta">
<p clas="my-4">Kampanja: {{ data.offer.campaign_name }}</p>
<p clas="my-4">Norma e interesit: {{ data.offer.interest_rate_nominal }}</p>
<p clas="my-4">*Shpenzimet Administrative: {{ data.offer.admin_fee }}</p>
<p clas="my-4">Kësti Mujor: {{ data.offer.monthly_payment }}</p>
</b-modal>
</div>
</template>

<script>
export default {
props: ['data'],
computed:{
modalId(){
return 'modal' + this.data.i;
}
}
}
</script>

这里是一个使用模态的方法

<tbody>
<tr v-for="(offer, i) in offers">
<td>
<app-show-details :data="{offer, i}"></app-show-details>
</td>
</tr>
</tbody>

最佳答案

BootStrapVue provides more than one pattern to achieve modal ,所以你不必坚持使用指令修饰符,我认为使用指令值完全符合你的要求。检查下面的示例代码。

new Vue({
el: '#app',
methods: {
modalId(i) {
return 'modal' + i;
}
}
});

// or check jsfiddle here: https://jsfiddle.net/5sv805ho/
<script src="https://unpkg.com/vue@2.5.2/dist/vue.min.js"></script>
<link href="https://unpkg.com/bootstrap@next/dist/css/bootstrap.min.css" rel="stylesheet"/>
<link href="https://unpkg.com/bootstrap-vue@latest/dist/bootstrap-vue.css" rel="stylesheet"/>
<script src="https://unpkg.com/bootstrap-vue@latest/dist/bootstrap-vue.js"></script>
<div id="app">
<div v-for="i in 3">
<b-btn v-b-modal="modalId(i)">Launch demo modal</b-btn>
<b-modal :id="'modal' + i" title="Bootstrap-Vue">
<p clas="my-4">Hello from modal {{ i }}!</p>
</b-modal>
</div>
</div>

顺便说一下,you can also use show() and hide() component methods .

关于javascript - 如何在 v-for 循环中使用 BootstrapVue - Modal?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46950088/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com