微信小程序文字混合、填充动画有效果图

效果图

.wxml

复制代码
<view class="text" style="--deg:{{deg}}deg;">
  <view>混合父级颜色</view>
</view>
<view class="fill {{status?'action':''}}">文字颜色填充</view>
<button bind:tap="setStatus">{{status?'暂停':'开始'}}</button>

.js

复制代码
Page({
  data: {
    status:false,
    deg:0
  },
  setStatus(){
    var that = this
    const status = !that.data.status
    if(status){
      that.data.time = setInterval(function() {
        var deg = that.data.deg
        that.setData({
          deg:deg > 350?10:deg+10
        })
      },100)
    }else{
      clearInterval(that.data.time)
    }
    that.setData({
      status
    })
  },
})

.wxss

复制代码
.text{
  padding:50rpx 0;
  background: linear-gradient(var(--deg), #000 50% , #fff 50%);
}
.text>view{
  /* 元素的混合模式
  multiply   相乘:元素乘以背景并替换背景颜色,生成的颜色始终与背景一样暗;
  overlay    叠加:根据背景颜色对内容进行倍增或屏蔽,这与硬光混合模式相反;
  screen     屏幕:将背景和内容相乘,然后补充结果。这将导致内容比背景颜色更亮;
  difference 差值:这将从最亮的颜色中减去两种颜色中较深的一种;
  color      颜色混合:根据内容的色调和饱和度以及背景的亮度创建颜色;
  */
  mix-blend-mode: difference;
  text-align: center;
  color: #fff;
}

.fill{
  width: fit-content;
  margin: 50rpx auto;
  background:linear-gradient(135deg, #e54d42 10% , #f37b1d 20%, #fbbd08 30%, #8dc63f 40%, #39b54a 50%,
  #1cbbb4 60%, #0081ff 70%, #6739b6 80%, #9c26b0 90%, #e03997 100%);
  font-weight:700;
  /* 文字颜色填充 */
  -webkit-text-fill-color: transparent;
  /* 背景绘制区域 */
  -webkit-background-clip:text;
}
.fill.action{
  animation: filter infinite 3s;
}
/* 颜色旋转 */
@keyframes filter{
  from {
    filter:hue-rotate(360deg)
  }
  to {
    filter:hue-rotate(0deg)
  }
}
相关推荐
Lee川7 小时前
CSS盒模型实战:用代码透视 `border-box`与 `content-box`的天壤之别
css
2501_933907218 小时前
深圳本凡科技专业企业APP开发,助力手机应用创新优化
科技·微信小程序·小程序
java1234_小锋10 小时前
分享一套优质的微信小程序校园志愿者系统(SpringBoot后端+Vue3管理端)
微信小程序·小程序·校园志愿者
哈里谢顿12 小时前
CSS 入门完全指南:从零构建你的第一个样式表
css
. . . . .12 小时前
CSS 编写与管理范式 - Tailwind和CSS-in-JS
css
RFCEO1 天前
前端编程 课程十六、:CSS 盒子模型
css·前端基础课程·css盒子模型·css盒子模型的组成·精准控制元素的大小和位置·css布局的基石·内边距(padding)
“负拾捌”2 天前
python + uniapp 结合腾讯云实现实时语音识别功能(WebSocket)
python·websocket·微信小程序·uni-app·大模型·腾讯云·语音识别
夏幻灵2 天前
CSS三大特性:层叠、继承与优先级解析
前端·css
会编程的土豆2 天前
新手前端小细节
前端·css·html·项目
珹洺2 天前
Bootstrap-HTML(二)深入探索容器,网格系统和排版
前端·css·bootstrap·html·dubbo