Vue使用Element折疊面板Collapse如何設(shè)置默認(rèn)全部展開
Element折疊面板Collapse設(shè)置默認(rèn)全部展開
這個(gè)適用于需要for循環(huán) <el-collapse-item>
負(fù)責(zé)展開的屬性是value
<el-collapse :value="opened"> ? <el-collapse-item v-for="o in List" :key="o.aaa":name="o.aaa"> ? ? <div>XXXXXXXXXXXXXXXXXXXXXXXX</div> ? </el-collapse-item> </el-collapse> ? <script> ? export default { ? ? data() { ? ? ? return { ? ? ? ??? ?List:[ ? ? ? ??? ??? ?{? ? ? ? ??? ??? ??? ?aaa:"123" ? ? ? ??? ??? ?}, ? ? ? ??? ??? ?{ ? ? ? ??? ??? ??? ?aaa:"354" ? ? ? ??? ??? ?}, ? ? ? ??? ??? ?{ ? ? ? ??? ??? ??? ?aaa:"asfdvg" ? ? ? ??? ??? ?} ? ? ? ??? ?] ? ? ? }; ? ? }, ? ? ? computed: { ? ? ? ? ? ? opened() { ? ? ? ? ? ? ? ? return this.List.map((i) => { ? ? ? ? ? ? ? ? ? ? return i.aaa; ? ? ? ? ? ? ? ? }); ? ? ? ? ? ? } ? ? ? ? }, ? } </script>
:name 只要是子元素的唯一屬性即可
這時(shí)會(huì)有一個(gè)bug,當(dāng)頁(yè)面有數(shù)據(jù)發(fā)生變動(dòng)時(shí),這個(gè)折疊就會(huì)重新刷新,造成體驗(yàn)感變差的現(xiàn)象
Vue實(shí)現(xiàn)展開折疊效果
1、創(chuàng)建collapse.js文件
const elTransition = ? "0.3s height ease-in-out, 0.3s padding-top ease-in-out, 0.3s padding-bottom ease-in-out"; const Transition = { ? "before-enter"(el) { ? ? el.style.transition = elTransition; ? ? if (!el.dataset) el.dataset = {}; ? ? ? el.dataset.oldPaddingTop = el.style.paddingTop; ? ? el.dataset.oldPaddingBottom = el.style.paddingBottom; ? ? ? el.style.height = 0; ? ? el.style.paddingTop = 0; ? ? el.style.paddingBottom = 0; ? }, ? ? enter(el) { ? ? el.dataset.oldOverflow = el.style.overflow; ? ? if (el.scrollHeight !== 0) { ? ? ? el.style.height = el.scrollHeight + "px"; ? ? ? el.style.paddingTop = el.dataset.oldPaddingTop; ? ? ? el.style.paddingBottom = el.dataset.oldPaddingBottom; ? ? } else { ? ? ? el.style.height = ""; ? ? ? el.style.paddingTop = el.dataset.oldPaddingTop; ? ? ? el.style.paddingBottom = el.dataset.oldPaddingBottom; ? ? } ? ? ? el.style.overflow = "hidden"; ? }, ? ? "after-enter"(el) { ? ? el.style.transition = ""; ? ? el.style.height = ""; ? ? el.style.overflow = el.dataset.oldOverflow; ? }, ? ? "before-leave"(el) { ? ? if (!el.dataset) el.dataset = {}; ? ? el.dataset.oldPaddingTop = el.style.paddingTop; ? ? el.dataset.oldPaddingBottom = el.style.paddingBottom; ? ? el.dataset.oldOverflow = el.style.overflow; ? ? ? el.style.height = el.scrollHeight + "px"; ? ? el.style.overflow = "hidden"; ? }, ? ? leave(el) { ? ? if (el.scrollHeight !== 0) { ? ? ? el.style.transition = elTransition; ? ? ? el.style.height = 0; ? ? ? el.style.paddingTop = 0; ? ? ? el.style.paddingBottom = 0; ? ? } ? }, ? ? "after-leave"(el) { ? ? el.style.transition = ""; ? ? el.style.height = ""; ? ? el.style.overflow = el.dataset.oldOverflow; ? ? el.style.paddingTop = el.dataset.oldPaddingTop; ? ? el.style.paddingBottom = el.dataset.oldPaddingBottom; ? } }; ? export default { ? name: "collapseTransition", ? functional: true, ? render(h, { children }) { ? ? const data = { ? ? ? on: Transition ? ? }; ? ? return h("transition", data, children); ? } };
2、在.vue組件中引入
<template> ? ? <div class="container"> ? ? ? ? <button @click="isActive = !isActive">展開/折疊</button> ? ? ? ? <collapse> ? ? ? ? ? ? <div v-show="isActive"> ? ? ? ? ? ? ? ? <div style="border:1px solid #ddd;padding:10px;"> ? ? ? ? ? ? ? ? <h2>歡迎大家品嘗Pizza!</h2> ? ? ? ? ? ? ? ? <h5>這里有你非常喜歡的Pizza!</h5> ? ? ? ? ? ? ? ? </div> ? ? ? ? ? ? </div> ? ? ? ? </collapse> ? ? ? ? <div> ? ? ? ? ? ? 666 ? ? ? ? </div> ? ? </div> </template> <script> import collapse from "#/assets/js/collapse.js"; export default { ? data() { ? ? return { ? ? ? isActive: false ? ? }; ? }, ? components: { ? ? collapse ? } }; </script>
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vuejs 實(shí)現(xiàn)簡(jiǎn)易 todoList 功能 與 組件實(shí)例代碼
本文通過實(shí)例代碼給大家介紹了Vuejs 實(shí)現(xiàn)簡(jiǎn)易 todoList 功能 與 組件,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09vite+vue3項(xiàng)目中svg圖標(biāo)組件封裝的過程詳解
這篇文章主要介紹了vite+vue3項(xiàng)目中svg圖標(biāo)組件封裝的過程,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-03-03Vue+SSM實(shí)現(xiàn)圖片上傳預(yù)覽效果
這篇文章主要為大家詳細(xì)介紹了Vue+SSM實(shí)現(xiàn)圖片上傳預(yù)覽效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11vue: WebStorm設(shè)置快速編譯運(yùn)行的方法
今天小編就為大家分享一篇vue: WebStorm設(shè)置快速編譯運(yùn)行的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2018-10-10Nuxt.js之自動(dòng)路由原理的實(shí)現(xiàn)方法
這篇文章主要介紹了Nuxt.js之自動(dòng)路由原理的實(shí)現(xiàn)方法,nuxt.js會(huì)根據(jù)pages目錄結(jié)構(gòu)自動(dòng)生成vue-router模塊的路由配置。非常具有實(shí)用價(jià)值,需要的朋友可以參考下2018-11-11vue實(shí)現(xiàn)鼠標(biāo)經(jīng)過動(dòng)畫
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)鼠標(biāo)經(jīng)過動(dòng)畫的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10