欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue使用Element折疊面板Collapse如何設(shè)置默認(rèn)全部展開

 更新時(shí)間:2023年01月18日 11:00:12   作者:suzhiwei_boke  
這篇文章主要介紹了Vue使用Element折疊面板Collapse如何設(shè)置默認(rèn)全部展開,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

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í)例代碼

    Vuejs 實(shí)現(xiàn)簡(jiǎn)易 todoList 功能 與 組件實(shí)例代碼

    本文通過實(shí)例代碼給大家介紹了Vuejs 實(shí)現(xiàn)簡(jiǎn)易 todoList 功能 與 組件,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-09-09
  • vite+vue3項(xiàng)目中svg圖標(biāo)組件封裝的過程詳解

    vite+vue3項(xiàng)目中svg圖標(biāo)組件封裝的過程詳解

    這篇文章主要介紹了vite+vue3項(xiàng)目中svg圖標(biāo)組件封裝的過程,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2024-03-03
  • Vue+SSM實(shí)現(xiàn)圖片上傳預(yù)覽效果

    Vue+SSM實(shí)現(xiàn)圖片上傳預(yù)覽效果

    這篇文章主要為大家詳細(xì)介紹了Vue+SSM實(shí)現(xiàn)圖片上傳預(yù)覽效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • 詳解nuxt路由鑒權(quán)(express模板)

    詳解nuxt路由鑒權(quán)(express模板)

    這篇文章主要介紹了詳解nuxt路由鑒權(quán)(express模板),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • vue: WebStorm設(shè)置快速編譯運(yùn)行的方法

    vue: WebStorm設(shè)置快速編譯運(yùn)行的方法

    今天小編就為大家分享一篇vue: WebStorm設(shè)置快速編譯運(yùn)行的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2018-10-10
  • vite vue3 路由配置@找不到文件的問題及解決

    vite vue3 路由配置@找不到文件的問題及解決

    在Vite項(xiàng)目中配置路由時(shí),可能會(huì)遇到文件路徑錯(cuò)誤導(dǎo)致的加載失敗問題,常見的解決辦法包括安裝路徑處理插件、正確設(shè)置vite.config.js中的路徑別名以及重啟項(xiàng)目,通過正確配置,可以確保路由正確加載對(duì)應(yīng)的界面文件,避免路徑錯(cuò)誤導(dǎo)致的問題
    2024-10-10
  • vue3如何監(jiān)聽頁(yè)面的滾動(dòng)

    vue3如何監(jiān)聽頁(yè)面的滾動(dòng)

    這篇文章主要給大家介紹了關(guān)于vue3如何監(jiān)聽頁(yè)面的滾動(dòng)的相關(guān)資料,在vue中實(shí)現(xiàn)滾動(dòng)監(jiān)聽和原生js無(wú)太大差異,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • Nuxt.js之自動(dòng)路由原理的實(shí)現(xiàn)方法

    Nuxt.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-11
  • vue3?vscode插件volar配置教程

    vue3?vscode插件volar配置教程

    這篇文章主要介紹了vue3?vscode插件volar配置,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07
  • vue實(shí)現(xiàn)鼠標(biāo)經(jīng)過動(dòng)畫

    vue實(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

最新評(píng)論