transition组件

一、vue里面的transition组件

Vue提供了这个transition组件,可以使得在v-if条件渲染、v-show条件显示、动态组件的时候可以给到任意元素和组件添加了进入或离开元素过渡。

二、transition组件应用CSS过渡

在应用css过渡的时候,transition组件会在恰当的时候添加、删除元素。我们的transition组件包含了一下6类过渡类别;

  • v-enter:定义在进入过渡的时候,元素在插入之前生效,在元素被插入之后的下一帧溢出。
  • v-enter-active:在定义的时候,在过渡生效的状态,在整个进入过渡的阶段中应用,在元素被插入前生效,在过渡完成之后移除。
  • v-enter-to:定义进入过渡的结束状态,在元素被插入之后下一帧生效,过渡完成后移除。
  • v-leave:定义在离开过渡的开始状态,在离开过渡被触发的时候立刻生效,下一帧就会被移出。
  • v-leave-active:在定义离开的过渡生效时状态。
  • v-leave-to:定义在离开过渡的结束状态。

我们总结的这6个过渡类,前三个是进入过渡的类,后面三个是离开过渡的类,在进入或者离开的过程中,这里6个过渡类之间相互切换。

(1)单元数/组件过渡

在transition组件中只会包含一个元素,在这个元素插入或者删除的时候定义过渡。我们可以通过一行代码段进行了解一下:

实例代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

<!DOCTYPE html>

<html lang="en">

<head>

    <title>动态</title>

</head>

<body>

    <div id="app">

<input type="checkbox" v-model="guodu" id="game"/>

<label for="game">我已经知晓未成年人游戏时间公告</label>

<transition name="fade">

    <p v-if="guodu"><button>开始游戏</button></p>

</transition>

    </div>

    <script src="http://cdn.staticfile.org/vue/2.2.2/vue.min.js"></script>

<script>

    var vm = new Vue({

        el:"#app",

        data:{guodu:false}

    });

</script>

<style>

    .fade-enter,

    .fade-leave-to {

        opacity: 0;

        transform: translateX(100px);

    }

    .fade-enter-active,

    .fade-leave-active {

        transition: all 2s;

    }

</style>

</body>

</html>

我们的组件设置了name=“fade”,然后可以在定义样式的时候用到fade的前缀,如代码中的.fade-enter等等,这样定义好样式以后,就不用进行手动引入了,transition组件就可以将我们“开始游戏”按钮的元素恰到好处的添加以及删除操作。

(2)多个元素过渡

transition组件包含多个元素,这一些元素在插入或者删除的时候就可以定义过渡。我们还是通过代码了解一下,不用大肆修改,其他的代码就不用修改了,我们只要在前面的单个元素部分的章节上面进行修改就可以了。

实例代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

<!DOCTYPE html>

<html lang="en">

<head>

    <title>动态</title>

</head>

<body>

    <div id="app">

<input type="checkbox" v-model="DGguodu" id="game"/>

<label for="game">我已经知晓未成年人游戏时间公告</label>

<transition name="fade" appear mode="out-in">

    <p v-if="DGguodu" key="1"><button>开始游戏</button></p>

    <p v-else key="2">先阅读公告后进行游戏</p>

</transition>

    </div>

    <script src="http://cdn.staticfile.org/vue/2.2.2/vue.min.js"></script>

<script>

    var vm = new Vue({

        el:"#app",

        data:{DGguodu:false}

    });

</script>

<style>

    .fade-enter,

    .fade-leave-to {

        opacity: 0;

        transform: translateX(100px);

    }

    .fade-enter-active,

    .fade-leave-active {

        transition: all 2s;

    }

</style>

</body>

</html>

我们将transition设置成了appear模式属性,这个属性用于设置节点在初始渲染的时候也应用过渡的效果。当我们选择复用框的时候,“我们给mode设置成了out-in,mode属性用来设置过渡模式。

(3)多个组件过渡

多个组件的过渡比多个元素过渡更加的简单,因为他不像元素过渡的时候使用到key属性,只需要使用动态组件即可。

(4)列表过渡

列表过渡使用的是transition-group组件,不同于transition这个组件的是,transition-group这个组件含有更多的属性特性,比如:mode属性不可用、内部只能含有一个key属性、css过渡得嘞将会应用在内部元素、渲染的时候以一个真实的元素呈现。我们通过代码进行了解一下这个列表过渡:

实例代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

<!DOCTYPE html>

<html lang="en">

<head>

    <title>列表过渡</title>

</head>

<body>

    <div id="app">

        <h1>2022届大学生新生入学登记:</h1>

<form>

    <p><label for="name">姓名:</label>

    <input type="text" v-model="stuInfo.name" id="name"></p>

    <p><label for="xuehao">学号:</label>

    <input type="xuehao" v-model="stuInfo.xuehao" id="xuehao"></p>

<p><button @click="add" type="button">添加</button></p>

</form>

<transition-group tag="ul" name="fade">

    <li v-for="(item,index) in students" :key="item.xuehao">{{index+1}}--{{item.name}}--{{item.xuehao}}<button @click="del(index)">删除</button>

    </li>

</transition-group>

    </div>

    <script src="http://cdn.staticfile.org/vue/2.2.2/vue.min.js"></script>

<script>

    var vm = new Vue({

        el:"#app",

        data:{

            stuInfo:{xuehao:"  "},

            students:[]

        },

        methods:{

            add(){

                this.students.push(this.stuInfo);

                this.stuInfo={};

            },

            del(index){this.students.splice(index,1);}

        }

    });

</script>

<style>

    .fade-enter,

    .fade-leave-to {

        opacity: 0;

        transform: translateX(100px);

    }

    .fade-enter-active,

    .fade-leave-active {

        transition: all 2s;

    }

</style>

</body>

</html>

三、JavaScript钩子

JavaScript的钩子函数可以使用transition组件里面的v-on指令绑定,transition过渡的周期可以有以下钩子函数:

1

2

3

4

5

6

7

8

9

10

<transition v-on:before-enter="beforeEnter"

v-on:enter="enter"

v-on:after-enter="afterenter"

v-on:enter-cancelled="entercanclled"

v-on:before-leave="beforeLeave"

v-on:leave="leave"

v-on:after-leave="afterLeave"

v-on:leave-cancelled="leaveCancelled"

>

</transition>

实例代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

<!DOCTYPE html>

<html lang="en">

<head>

    <title>钩子函数实现动画</title>

</head>

<body>

    <div id="app">

        <input type="checkbox" v-model="already" id="ck"/>

        <label for="ck">我已经阅读了相关的报名需求</label>

        <transition

         @before-enter="beforeEnter"

         @enter="enter"

         @after-enter="after-enter"

        >

    <p class="show" v-if="already"><button>确定报名</button></p></transition>

    </div>

    <script src="http://cdn.staticfile.org/vue/2.2.2/vue.min.js"></script>

<script>

    var vm = new Vue({

        el:"#app",

        data:{

already:false

        },

        methods:{

            beforeEnter:function(el){

                el.style="opacity:0";console.log("beforeEnter");

            },

            enter:function(el,done) {

                el.offsetHeight;

                el.style = "opacity:1";

                console.log("enter");

                done();

            },

            afterEnter:function(el){

                console.log("afterEnter");

            }

        }

    });

</script>

<style>

    .show {

        transition: all 2s;

    }

</style>

</body>

</html>

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值