亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue中transition標(biāo)簽的基本使用教程

 更新時(shí)間:2022年08月26日 10:38:52   作者:Superman_H  
Vue提供了transition的封裝組件,可以給任何元素和組件添加進(jìn)入/離開過渡,下面這篇文章主要給大家介紹了關(guān)于Vue中transition標(biāo)簽基本使用的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

transition 標(biāo)簽

transition 標(biāo)簽:Vue 的內(nèi)置動(dòng)畫標(biāo)簽

作用:在 [插入] / [更新] / [移除] DOM 元素時(shí),在合適的時(shí)候給元素添加樣式類名(配合 CSS 樣式使用,實(shí)現(xiàn)動(dòng)畫效果)

注意事項(xiàng)

transition 標(biāo)簽只能包含 1 個(gè)元素;如果里面寫了多個(gè)元素,則只生效第一個(gè)

transition 包裹的標(biāo)簽需要設(shè)置 v-show / v-if 屬性控制元素的顯示

動(dòng)畫 CSS 樣式對(duì)應(yīng)的類名

進(jìn)入:.v-enter 始狀態(tài)、.v-enter-to 末狀態(tài)、.v-enter-active 進(jìn)入動(dòng)畫(Vue2)

離開:.v-leave 始狀態(tài)、.v-leave-to 末狀態(tài)、.v-leave-active 離開動(dòng)畫(Vue2)

進(jìn)入:.v-enter-from 始狀態(tài)、.v-enter-to 末狀態(tài)、.v-enter-active 進(jìn)入動(dòng)畫(Vue3)

離開:.v-leave-from 始狀態(tài)、.v-leave-to 末狀態(tài)、.v-leave-active 離開動(dòng)畫(Vue3)

配合 animation

<template>
    <div>
        <button @click="bol = !bol">隱藏/顯示</button>
        <!-- Vue 的內(nèi)置動(dòng)畫標(biāo)簽 transition -->
        <transition>
            <!-- 只能包含 1 個(gè)元素 -->
            <h1 v-show="bol">組件動(dòng)畫效果</h1>
            <!-- 需要設(shè)置 v-show / v-if 屬性控制元素的顯示 -->
        </transition>
    </div>
</template>

<script>
export default {
    name: "App",
    data() {
        return { bol: true };
    },
};
</script>

<style>
/* 進(jìn)入動(dòng)畫 */
.v-enter-active {
    animation: move 1s;
}

/* 離開動(dòng)畫 */
.v-leave-active {
    animation: move 1s reverse;
}

@keyframes move {
    from {
        transform: translateX(-100%);
    }
    to {
        transform: translate(0);
    }
}
</style>
transition 標(biāo)簽的屬性

1、name 屬性:用于自動(dòng)生成 CSS 動(dòng)畫類名

如果 transition 標(biāo)簽元素沒有設(shè)置 name 屬性,則對(duì)應(yīng)的動(dòng)畫類名為 v-XXX

如果設(shè)置了 name 屬性,則對(duì)應(yīng)的動(dòng)畫類名為 屬性值-XXX

2、appear 屬性:一開始就生效顯示動(dòng)畫

<template>
    <div>
        <button @click="bol = !bol">隱藏/顯示</button>
        <!-- transition 標(biāo)簽元素設(shè)置了 name、appear 屬性 -->
        <transition name="moveCartoon" appear>
            <!-- 動(dòng)畫會(huì)在一開始便生效 -->
            <h1 v-show="bol">組件動(dòng)畫效果</h1>
        </transition>
    </div>
</template>

<script>
export default {
    name: "App",
    data() {
        return { bol: true };
    },
};
</script>

<style>
/* 類名要對(duì)應(yīng)回 name 的屬性值 */
.moveCartoon-enter-active {
    animation: move 1s;
}
.moveCartoon-leave-active {
    animation: move 1s reverse;
}

@keyframes move {
    from {
        transform: translateX(-100%);
    }
    to {
        transform: translate(0);
    }
}
</style>

當(dāng)存在多個(gè) tansition 標(biāo)簽時(shí),我們可以通過 name 屬性給各個(gè) transition 標(biāo)簽指定不同的 CSS 動(dòng)畫效果

配合 transition

<template>
    <div id="app">
        <button @click="bol = !bol">隱藏/顯示</button>
        <transition appear>
            <h1 v-show="bol">組件動(dòng)畫</h1>
        </transition>
    </div>
</template>

<script>
export default {
    name: "App",
    data() {
        return { bol: true };
    },
};
</script>

<style>
/* 進(jìn)入:始狀態(tài) */
.v-enter {
    transform: translateX(-100%);
}
/* 進(jìn)入:末狀態(tài) */
.v-enter-to {
    transform: translateX(0);
}
/* 進(jìn)入動(dòng)畫 */
.v-enter-active {
    transition: 1s;
}

/* 離開:始狀態(tài) */
.v-leave {
    transform: translateX(0);
}
/* 離開:末狀態(tài) */
.v-leave-to {
    transform: translateX(-100%);
}
/* 離開動(dòng)畫 */
.v-leave-active {
    transition: 1s;
}
</style>

也可以將 transition: 1s; 設(shè)置到標(biāo)簽上,就不用寫 v-leave-active、v-enter-active 對(duì)應(yīng)的樣式了

h1 {
    transition: 1s;
}

/* 進(jìn)入:始位置 */
.v-enter {
    transform: translateX(-100%);
}
/* 進(jìn)入:末位置 */
.v-enter-to {
    transform: translateX(0);
}

/* 離開:始位置 */
.v-leave {
    transform: translateX(0);
}
/* 離開:末位置 */
.v-leave-to {
    transform: translateX(-100%);
}

transition-group 標(biāo)簽

  • transition 標(biāo)簽只能包含 1 個(gè)元素、 transition-group 標(biāo)簽可以包含多個(gè)元素
  • transition-group 標(biāo)簽里面的元素需要設(shè)置 key 屬性,作為當(dāng)前元素的唯一標(biāo)識(shí)
  • 除此之外,其他用法都和 transition 標(biāo)簽一樣
<template>
    <div id="app">
        <button @click="isEditing = !isEditing">切換</button>
        <transition-group appear>
            <h1 v-if="isEditing" key="save">Save</h1>
            <h1 v-if="!isEditing" key="edit">Edit</h1>
        </transition-group>
    </div>
</template>

<script>
export default {
    name: "App",
    data() {
        return { isEditing: true };
    },
};
</script>

<style>
h1 {
    transition: 0.5s;
    position: absolute;
}
.v-leave {
    opacity: 1;
}
.v-leave-to {
    opacity: 0;
}
.v-enter {
    opacity: 0;
}
.v-enter-to {
    opacity: 1;
}
</style>

如果只有兩個(gè)元素,也可以給一個(gè)元素的 key 設(shè)置不同的狀態(tài)來代替 v-ifv-else,上面的例子可以重寫為:

<transition>
    <h1 :key="isEditing">
        {{ isEditing ? "Save" : "Edit" }}
    </h1>
</transition>

動(dòng)畫庫 animate.css

  1. 下載:npm install animate.css
  2. 引入樣式庫:import "animate.css"
  3. 給指定的 transition 標(biāo)簽添加 name 屬性 animate_animate、animate__bounce
  4. 配置 enter-active-class 屬性,指定進(jìn)入動(dòng)畫:
    在樣式庫中挑一個(gè)進(jìn)入的樣式值,作為 enter-active-class 屬性值
  5. 配置 leave-active-class 屬性,指定退出動(dòng)畫:
    在樣式庫中挑一個(gè)退出的樣式值,作為 leave-active-class 屬性值
<template>
    <div>
        <button @click="bol = !bol">隱藏 / 顯示</button>
        <transition
            name="animate__animated animate__bounce"
            enter-active-class="animate__bounceIn"
            leave-active-class="animate__bounceOut"
        >
            <h1 v-show="bol">動(dòng)畫庫的使用</h1>
        </transition>
    </div>
</template>

<script>
import "animate.css"; // 引入樣式庫
export default {
    name: "App",
    data() {
        return { bol: true };
    },
};
</script>

總結(jié)

到此這篇關(guān)于Vue中transition標(biāo)簽基本使用的文章就介紹到這了,更多相關(guān)Vue transition標(biāo)簽使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論