>>分享Web前端开发技术,并对孙卫琴的《精通Vue.js:Web前端开发技术详解》提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 16165 个阅读者 刷新本主题
 * 贴子主题:  vue的CSS过渡和动画范例 回复文章 点赞(0)  收藏  
作者:flybird    发表时间:2024-04-30 05:05:02     消息  查看  搜索  好友  邮件  复制  引用

官方比较正式的解释请点击下方链接:
https://cn.vuejs.org/v2/guide/transitions.html

transition里的元素触发了v-if或者 v-show之类的操作时候,Vue 将会做处理:
自动嗅探目标元素是否应用了 CSS 过渡或动画,如果是,在恰当的时机添加/删除 CSS 类名(本例用的是css方式,话说,能用css解决的为什么要麻烦js~~)。

过渡的类名有六种,代码中css里有备注说明各个类名的用途。

如果你使用一个没有名字的 <transition>这些类名的默认前缀。如果你使用了 <transition name="fade">,那么 v-enter 会替换为 fade-enter。

接下来上代码:
<template>
  <div>
    <div>
      <mt-button @click="showBtn1 = !showBtn1">过渡</mt-button>
      <transition name="fade">
        <div style="margin-top: 20px;" v-show="showBtn1">我赌你的枪里没有子弹</div>
      </transition>
    </div>

    <div style="margin-top: 20px;">
      <mt-button @click="showBtn2 = !showBtn2">动画</mt-button>
      <transition name="bounce">
        <div style="margin-top: 20px;" v-if="showBtn2">我赌你的枪里没有子弹</div>
      </transition>
    </div>

  </div>
</template>

<script>
export default {
  data () {
    return {
      showBtn1: false,
      showBtn2: false,
    }
  },
  computed: {
  },
  methods:{
      
  }
}
</script>

<style lang="css" scoped>
   /* 元素开始进入前和离开后的状态(还没做过渡的样子,比如隐藏掉目标元素) */
  .fade-leave-to, .fade-enter{    
    opacity: 0;
    transform: translateY(30px) scale(0);
  }

  /* 元素进入后和离开前的状态,(做完过渡应该展示的样式,可不设置此项 )*/
  .fade-enter-to, .fade-leave{
    opacity: 1;
    transform: translateY(0) scale(1);
  }
/* 元素正处于进入和离开的过程中(过渡进行中)*/
  .fade-enter-active, .fade-leave-active{
    transition: all .3s;
  }

/* 动画类只需要写这两条css即可*/
  .bounce-enter-active {
    animation: bounce-in .6s;
  }
  .bounce-leave-active {
    animation: bounce-in .6s reverse;
  }
/* 定义元素要执行的动画*/
  @keyframes bounce-in {
    0% {
      transform: scale(0);
    }
    50% {
      transform: scale(1.2);
    }
    100% {
      transform: scale(1);
    }
  }
</style>

作者:赤焰妖狐
链接:https://www.jianshu.com/p/0ad70b90d49b
来源:简书



程序猿的技术大观园:www.javathinker.net

  Java面向对象编程-->输入与输出(上)
  JavaWeb开发-->Web运作原理(Ⅰ)
  JSP与Hibernate开发-->映射对象标识符
  Java网络编程-->ServerSocket用法详解
  精通Spring-->Vue指令
  Vue3开发-->虚拟DOM和render()函数
  webpack常用插件
  javaScript中==和===的区别详解
  vue 项目导出word格式文件
  前端图片压缩库images-quickly-compress
  vue+file-saver+jszip实现批量导出图片
  用Vue-Awesome-Swiper实现旋转叠加轮播效果,平移轮播效果
  JS对树形数据的遍历和过滤,
  js导出json文件
  jQuery 效果:隐藏和显示
  jQuery UI 范例 - 选择条目(Selectable)
  CSS margin(外边距)
  HTML支持的多媒体(Media)
  JavaScript 函数参数
  JavaScript 调试
  用JavaScript制作弹出页面
  更多...
 IPIP: 已设置保密
楼主      
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。