css 不错的按钮动画

效果图

wxml

bash 复制代码
<view class="{{status?'active':''}}">
  <view class="up-top btn">
    <text>向上</text>
  </view>

  <view class="up-left btn">
    <text>向左</text>
  </view>

  <view class="up-center btn">
    <text>居中</text>
  </view>
</view>
<button bind:tap="hover">开始</button>

wxss

css 复制代码
.btn{
  margin:50rpx auto;
  width: 350rpx;
  height: var(--h);
  text-align: center;
  font-size: 32rpx;
  line-height: var(--h);

  --h:80rpx;
  --b:#0066FF;
}
.active{
  --p:100%;
  --s:.3s;
  --c:65%;
  color: #fff;
}
.up-top{
  background:conic-gradient(var(--b) 0 0) calc(200% - var(--p, 0%)) 100% / 200% var(--p, 4rpx) no-repeat;
  transition:.3s var(--s, 0s), background-position .3s calc(.3s - var(--s, 0s));
}
.up-left{
  background:conic-gradient(var(--b) 0 0) var(--p, 0%) / var(--p, 0%) no-repeat;
  transition:.3s, background-position 0s;
}
.up-center{
  background:conic-gradient(from -135deg at 100% 50%, var(--b) 90deg, transparent 0) 0 var(--p, 0%),
  conic-gradient(from -135deg at var(--h) 50%, transparent 90deg, var(--b) 0) 100% var(--p, 0%);
  background-size: var(--c, 0) 200%;
  background-repeat: no-repeat;
  transition:.3s ease-in, background-position 0s;
}

js

css 复制代码
Page({
  data: {
    status:false
  },
  hover(){
    var that = this
    that.setData({ status:true })
    setTimeout(() => { that.setData({ status:false }) },900)
  },
})

遇到问题可以看我主页加我Q,很少看博客,对你有帮助别忘记点赞收藏。

相关推荐
秃顶老男孩.13 小时前
异步处理(前端面试)
前端·面试·职场和发展
三脚猫的喵14 小时前
微信小程序中实现AI对话、生成3D图像并使用xr-frame演示
前端·javascript·ai作画·微信小程序
文心快码BaiduComate14 小时前
文心快码3.5S全新升级,体验多智能体协同开发,最高赢无人机!
前端·后端·程序员
安卓开发者14 小时前
鸿蒙Next ArkWeb进程解析:多进程架构如何提升Web体验
前端·架构·harmonyos
炒毛豆14 小时前
移动端响应式px转换插件PostCSS的使用~
前端·javascript·postcss
恋猫de小郭14 小时前
Flutter Riverpod 3.0 发布,大规模重构下的全新状态管理框架
android·前端·flutter
wordbaby14 小时前
用 window.matchMedia 实现高级响应式开发:API 全面解析与实战技巧
前端·javascript
薄雾晚晴14 小时前
Rspack 实战,构建流程升级:自动版本管理 + 命令行美化 + dist 压缩,一键输出生产包
前端·javascript
huabuyu14 小时前
在 Taro 小程序中实现完整 Markdown 渲染器的实践
前端
Running_slave14 小时前
位运算左移右移应该怎么玩?
前端·javascript·算法