Vue中transition標(biāo)簽的基本使用教程
transition 標(biāo)簽
transition 標(biāo)簽:Vue 的內(nèi)置動畫標(biāo)簽
作用:在 [插入] / [更新] / [移除] DOM 元素時,在合適的時候給元素添加樣式類名(配合 CSS 樣式使用,實現(xiàn)動畫效果)
注意事項
transition 標(biāo)簽只能包含 1 個元素;如果里面寫了多個元素,則只生效第一個
transition 包裹的標(biāo)簽需要設(shè)置 v-show / v-if 屬性控制元素的顯示
動畫 CSS 樣式對應(yīng)的類名
進入:.v-enter 始狀態(tài)、.v-enter-to 末狀態(tài)、.v-enter-active 進入動畫(Vue2)
離開:.v-leave 始狀態(tài)、.v-leave-to 末狀態(tài)、.v-leave-active 離開動畫(Vue2)
進入:.v-enter-from 始狀態(tài)、.v-enter-to 末狀態(tài)、.v-enter-active 進入動畫(Vue3)
離開:.v-leave-from 始狀態(tài)、.v-leave-to 末狀態(tài)、.v-leave-active 離開動畫(Vue3)

配合 animation
<template>
<div>
<button @click="bol = !bol">隱藏/顯示</button>
<!-- Vue 的內(nèi)置動畫標(biāo)簽 transition -->
<transition>
<!-- 只能包含 1 個元素 -->
<h1 v-show="bol">組件動畫效果</h1>
<!-- 需要設(shè)置 v-show / v-if 屬性控制元素的顯示 -->
</transition>
</div>
</template>
<script>
export default {
name: "App",
data() {
return { bol: true };
},
};
</script>
<style>
/* 進入動畫 */
.v-enter-active {
animation: move 1s;
}
/* 離開動畫 */
.v-leave-active {
animation: move 1s reverse;
}
@keyframes move {
from {
transform: translateX(-100%);
}
to {
transform: translate(0);
}
}
</style>
transition 標(biāo)簽的屬性
1、name 屬性:用于自動生成 CSS 動畫類名
如果 transition 標(biāo)簽元素沒有設(shè)置 name 屬性,則對應(yīng)的動畫類名為 v-XXX
如果設(shè)置了 name 屬性,則對應(yīng)的動畫類名為 屬性值-XXX
2、appear 屬性:一開始就生效顯示動畫
<template>
<div>
<button @click="bol = !bol">隱藏/顯示</button>
<!-- transition 標(biāo)簽元素設(shè)置了 name、appear 屬性 -->
<transition name="moveCartoon" appear>
<!-- 動畫會在一開始便生效 -->
<h1 v-show="bol">組件動畫效果</h1>
</transition>
</div>
</template>
<script>
export default {
name: "App",
data() {
return { bol: true };
},
};
</script>
<style>
/* 類名要對應(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)存在多個 tansition 標(biāo)簽時,我們可以通過 name 屬性給各個 transition 標(biāo)簽指定不同的 CSS 動畫效果
配合 transition
<template>
<div id="app">
<button @click="bol = !bol">隱藏/顯示</button>
<transition appear>
<h1 v-show="bol">組件動畫</h1>
</transition>
</div>
</template>
<script>
export default {
name: "App",
data() {
return { bol: true };
},
};
</script>
<style>
/* 進入:始狀態(tài) */
.v-enter {
transform: translateX(-100%);
}
/* 進入:末狀態(tài) */
.v-enter-to {
transform: translateX(0);
}
/* 進入動畫 */
.v-enter-active {
transition: 1s;
}
/* 離開:始狀態(tài) */
.v-leave {
transform: translateX(0);
}
/* 離開:末狀態(tài) */
.v-leave-to {
transform: translateX(-100%);
}
/* 離開動畫 */
.v-leave-active {
transition: 1s;
}
</style>
也可以將 transition: 1s; 設(shè)置到標(biāo)簽上,就不用寫 v-leave-active、v-enter-active 對應(yīng)的樣式了
h1 {
transition: 1s;
}
/* 進入:始位置 */
.v-enter {
transform: translateX(-100%);
}
/* 進入:末位置 */
.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 個元素、 transition-group 標(biāo)簽可以包含多個元素
- transition-group 標(biāo)簽里面的元素需要設(shè)置
key屬性,作為當(dāng)前元素的唯一標(biāo)識 - 除此之外,其他用法都和 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>
如果只有兩個元素,也可以給一個元素的 key 設(shè)置不同的狀態(tài)來代替 v-if 和 v-else,上面的例子可以重寫為:
<transition>
<h1 :key="isEditing">
{{ isEditing ? "Save" : "Edit" }}
</h1>
</transition>
動畫庫 animate.css
- 下載:npm install animate.css
- 引入樣式庫:import "animate.css"
- 給指定的 transition 標(biāo)簽添加 name 屬性 animate_animate、animate__bounce
- 配置 enter-active-class 屬性,指定進入動畫:
在樣式庫中挑一個進入的樣式值,作為 enter-active-class 屬性值 - 配置 leave-active-class 屬性,指定退出動畫:
在樣式庫中挑一個退出的樣式值,作為 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">動畫庫的使用</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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
uniapp中使用u-loadmore,loadText內(nèi)容不隨status改變刷新方式
這篇文章主要介紹了uniapp中使用u-loadmore,loadText內(nèi)容不隨status改變刷新方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05
vue-cli 2.*中導(dǎo)入公共less文件的方法步驟
這篇文章主要介紹了vue-cli 2.*中導(dǎo)入公共less文件的方法步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11
如何解決element-ui中select下拉框popper超出彈框問題
這篇文章主要介紹了如何解決element-ui中select下拉框popper超出彈框問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-04-04
Vue手把手教你擼一個 beforeEnter 鉤子函數(shù)
這篇文章主要介紹了Vue手把手教你擼一個 beforeEnter 鉤子函數(shù),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04

