14.Vue3过渡和动画实现

1.认识动画

给组件显示和消失添加某种过渡动画,可以增加用户体验。
react本身不提供任何动画相关的API,需要使用第三方库react-transition-group
Vue提供一些内置组件和对应的API来完成动画,可以方便实现过渡动画效果。

<button @click="isshow=!isshow">显示/隐藏</button>
<h2 v-if="isshow">Hello World</h2>

在这里插入图片描述
没有动画的情况下,内容显示或隐藏会非常生硬,给单元素或者组件实现过渡动画,可以使用transition内置组件

将要实现动画的单个元素或者组件嵌套再transition中,设置name。

<transition name="anima">
	<h2 v-if="isshow">Hello World</h2>
</transition>

在样式中设置过渡:

<style scoped>
	.anima-enter-from,
	.anima-leave-to{
		opacity: 0;
	}
	.anima-leave-from,
	.anima-enter-to{
		opacity: 1;
	}
	.anima-enter-active,
	.anima-leave-active{
		transition: opacity 2s ease;
	}
</style>

2.transition组件的原理

当插入或删除包含在transition组件的元素中时,vue将会做以下处理:
1.自动嗅探目标元素是否应用了CSS过渡或者动画,如果有,那么在恰当的时机添加/删除 CSS类名;
2.如果transition组件提供了JavaScript钩子函数,这些钩子函数在恰当的时机会被调用;
3.如果没有找到JavaScript钩子并且也没有检测到CSS过渡/动画,DOM插入、删除操作将会立即执行。

在这里插入图片描述
class的命名规则
如果我们使用的是一个没有name的transition,class的命名以v-作为默认前缀。
如果我们添加了一个name属性,例如:<transition name="anima">那么class

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue提供了过渡动画的内置支持,可以通过Vue的transition组件来实现过渡动画。在transition组件中,可以定义进入动画、离开动画过渡模式等。同时,CSS也提供了丰富的动画效果,可以通过CSS的transition属性来实现过渡动画。 下面是一个使用Vue和CSS实现过渡动画的示例: ```html <template> <div> <button @click="show = !show">Toggle</button> <transition name="fade"> <p v-if="show">Hello, World!</p> </transition> </div> </template> <style> .fade-enter-active, .fade-leave-active { transition: opacity 0.5s; } .fade-enter, .fade-leave-to { opacity: 0; } </style> <script> export default { data() { return { show: false }; } }; </script> ``` 在上面的示例中,我们定义了一个按钮和一个包裹着文本的transition组件。文本的显示与隐藏通过控制show属性来实现。同时,我们也定义了一个名为"fade"的transition,它定义了进入和离开动画的方式。 在CSS中,我们定义了两个类名为"fade-enter-active"和"fade-leave-active",它们分别表示进入和离开动画的状态。这里我们使用了CSS的transition属性,它指定了过渡的属性和时长。在这个例子中,我们使用opacity属性和0.5秒的时长来实现淡入淡出的效果。 同时,我们也定义了类名为"fade-enter"和"fade-leave-to",它们分别表示进入和离开动画的初始和结束状态。在这个例子中,我们将opacity属性的值设置为0,表示文本初始时是透明的,离开时也是透明的。 通过这样的方式,我们就可以使用Vue和CSS来实现过渡动画了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值