微信小程序纯CSS实现好看的加载动画

news/2024/7/20 2:26:43 标签: 微信小程序, css, 小程序

进入下面小程序可以体验效果

 

WXML:

<wxs module="img" src="./loading.wxs"></wxs>
<view class="loading-container {{show?'':'loading-container-hide'}}">
    <view class="loading-mask" wx:if="{{mask&&show}}"></view>
    <view class="loading-mask-solid {{!mask&&show?'':'loading-mask-solid-hide'}}"></view>
    <view class="loading">
        <view class="loading-inner {{open?'loading-inner-open':''}}"></view>
        <view class="loading-circle"></view>
        <view class="loading-petal {{open?'loading-petal-open':''}}">
            <view class="loading-petal-1">
                <image src="{{img.imgBase64}}"></image>
            </view>
            <view class="loading-petal-2">
                <image src="{{img.imgBase64}}"></image>
            </view>
            <view class="loading-petal-3">
                <image src="{{img.imgBase64}}"></image>
            </view>
            <view class="loading-petal-4">
                <image src="{{img.imgBase64}}"></image>
            </view>
            <view class="loading-petal-5">
                <image src="{{img.imgBase64}}"></image>
            </view>
        </view>
    </view>
</view>

WXSS:

css">.loading-container{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    width: 100%;
    opacity: 1;
}

.loading-container-hide{
    opacity: 0;
    transform: scale(0);
    transition: all 0.7s;
}

.loading-mask{
    height: 100%;
    width: 100%;
    position: absolute;
    backdrop-filter: blur(5px);
    background: #ffffffad;
}

.loading-mask-solid{
    height: 100%;
    width: 100%;
    position: absolute;
    background: white;
}

.loading-mask-solid-hide{
    opacity: 0;
    transition: all 0.5s;
}

.loading{
    position: absolute;
    width: 200rpx;
    height: 200rpx;
    animation: loadingMove 1.5s alternate infinite;
    animation-timing-function: ease;
    display: flex;
    justify-content: center;
    align-items: center;
}

.loading-petal{
    position: absolute;
    opacity: 0;
    width: 160rpx;
    height: 160rpx;
    transform: scale(0.5);
}

.loading-petal-open{
    opacity: 1;
    transform: scale(1.2);
    transition: all 0.5s;
}

.loading-petal-1{
    position: absolute;
    animation: loadingpetal linear infinite 1.5s;
}

.loading-petal-2{
    position: absolute;
    animation: loadingpetal linear infinite 4s;
}

.loading-petal-3{
    position: absolute;
    animation: loadingpetal linear infinite reverse 2s;
}

.loading-petal-4{
    position: absolute;
    animation: loadingpetal linear infinite reverse 3.5s;
}

.loading-petal-5{
    position: absolute;
    animation: loadingpetal linear infinite reverse 4.5s;
}

@keyframes loadingpetal {
    from {
      transform: rotate(0);
    }
    to {
      transform: rotate(360deg);
    }
}


image{
    width: 160rpx;
    height: 160rpx;
}

.loading-inner{
    width: 65rpx;
    height: 65rpx;
    background: rgb(71 135 255);
    border-radius: 100px;
    display: flex;
    justify-content: center;
    align-items: center;
    
}

.loading-inner-open{
    background: rgb(0 66 189);
    width: 110rpx;
    height: 110rpx;
    transition: all 0.5s;
}

@keyframes loadingMove {
    0%,100%{
        transform: translateY(0);
    }
    50%{
        transform: translateY(-8px);
    }
}

.loading-circle {
    position: absolute;
    z-index: 99;
    font-size: 16px;
    width: 16px;
    height: 16px;
    display: block;
    background: transparent url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg width='80px' height='80px' viewBox='0 0 80 80' version='1.1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink'%3E%3Ctitle%3Eloading%3C/title%3E%3Cdefs%3E%3ClinearGradient x1='94.0869141%25' y1='0%25' x2='94.0869141%25' y2='90.559082%25' id='linearGradient-1'%3E%3Cstop stop-color='%23ffffff' stop-opacity='0' offset='0%25'%3E%3C/stop%3E%3Cstop stop-color='%23ffffff' stop-opacity='0' offset='100%25'%3E%3C/stop%3E%3C/linearGradient%3E%3ClinearGradient x1='100%25' y1='8.67370605%25' x2='100%25' y2='90.6286621%25' id='linearGradient-2'%3E%3Cstop stop-color='%23ffffff' offset='0%25'%3E%3C/stop%3E%3Cstop stop-color='%23ffffff' stop-opacity='0' offset='100%25'%3E%3C/stop%3E%3C/linearGradient%3E%3C/defs%3E%3Cg stroke='none' stroke-width='1' fill='none' fill-rule='evenodd' opacity='0.9'%3E%3Cg%3E%3Cpath d='M40,0 C62.09139,0 80,17.90861 80,40 C80,62.09139 62.09139,80 40,80 L40,73 C58.2253967,73 73,58.2253967 73,40 C73,21.7746033 58.2253967,7 40,7 L40,0 Z' fill='url(%23linearGradient-1)'%3E%3C/path%3E%3Cpath d='M40,0 L40,7 C21.7746033,7 7,21.7746033 7,40 C7,58.2253967 21.7746033,73 40,73 L40,80 C17.90861,80 0,62.09139 0,40 C0,17.90861 17.90861,0 40,0 Z' fill='url(%23linearGradient-2)'%3E%3C/path%3E%3Ccircle id='Oval' fill='%23ffffff' cx='40.5' cy='3.5' r='3.5'%3E%3C/circle%3E%3C/g%3E%3C/g%3E%3C/svg%3E%0A") no-repeat;
    background-size: 100%;
    animation: loading linear infinite 1s;
    animation-timing-function: ease;
  }


  @keyframes loading {
    from {
      transform: rotate(0);
    }
    to {
      transform: rotate(360deg);
    }
  }

JS:

// components/loading/loading.js
Component({
    lifetimes:{
        created(){

        },
        attached(){

        }
    },
    observers: {
        'show': function(show) {
            var that =this;
            if(show){
                setTimeout(()=>{
                    that.setData({open:true,mask:true})
                },that.data.burstTime)
            }else{
                that.setData({mask:false})
                setTimeout(()=>{
                    that.setData({open:false})
                },500)
            }
        }
    },
  /**
   * 组件的属性列表
   */
  properties: {
    /**
     * 是否显示
     */
    show:{
        type:Boolean,
        value:false
    },
    /**
     * 花瓣绽放时间
     */
    burstTime:{
        type:Number,
        value:1300
    }
  },

  /**
   * 组件的初始数据
   */
  data: {
    mask:false,
    open:false,
  },

  /**
   * 组件的方法列表
   */
  methods: {

  }
})

WXS:

var imagebase64=""

module.exports = {
    imgBase64: imagebase64
}

readme.me使用方式:

使用方式:
直接引入组件
<loading style="position: absolute;height: 100%;width: 100%;transition: all 0.2s;z-index: {{loadingShow?9999:0}};" 
    show="{{true}}" 
    burstTime="{{1000}}">
</loading>
说明:
    必须使用该style: position: absolute;height: 100%;width: 100%;transition: all 0.2s;z-index: {{loadingShow?9999:0}};
    show: 是否显示
    burstTime: 花瓣绽放时间 单位/ms. 参数0,直接显示花瓣加载动画


http://www.niftyadmin.cn/n/5471096.html

相关文章

C++ 11 的新特性

回答来自【通义灵码】 C11是C编程语言的一个重要里程碑&#xff0c;引入了大量的新特性以提升代码的可读性、可维护性、性能和安全性。以下是一些关键的C11新特性&#xff1a; 统一初始化: 允许在任何情况下使用花括号列表初始化&#xff08;uniform initialization&#xff0…

Jupyter IPython帮助文档及其魔法命令

1.IPython 的帮助文档 使用 help() 使用 ? 使用 &#xff1f;&#xff1f; tab 自动补全 shift tab 查看参数和函数说明 2.运行外部 Python 文件 使用下面命令运行外部 Python 文件&#xff08;默认是当前目录&#xff0c;也可以使用绝对路径&#xff09; %run *.py …

代码随想录算法训练营第二十九天|491.非递减子序列、46.全排列、47全排列II

代码随想录算法训练营第二十九天|491.非递减子序列、46.全排列、47全排列II 491.非递减子序列 给你一个整数数组 nums &#xff0c;找出并返回所有该数组中不同的递增子序列&#xff0c;递增子序列中 至少有两个元素 。你可以按 任意顺序 返回答案。 数组中可能含有重复元素…

嵌入式_RP2040

文章目录 一、环境配置二、下载烧录到开发板三、调试 PICO1. 使用 picoprobe 调试树莓派 PICO1.1. 命令行 调试1.2. IDE 调试一、环境配置 安装依赖sudo apt install cmake gcc-arm-none-eabi libnewlib-arm-none-eabi libstdc++-arm-none-eabi-newlib配置环境变量echo "e…

光伏发电属于高新技术产业吗?

太阳能电池是太阳能光伏发电系统的核心组成部分&#xff0c;其工作原理是利用半导体材料在太阳光的作用下产生电势差&#xff0c;从而将太阳光能转化为电能。太阳能光伏发电系统可以属于新能源行业&#xff0c;按传统划分可以属于电力行业&#xff1b;按材料划分可以属于光伏行…

1 【机器学习】统计学习的概念

&#x1f388;个人主页&#xff1a;豌豆射手^ &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f917;收录专栏&#xff1a;李航统计学习笔记 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共同学习…

Swift 代码注释的使用

Swift代码注释的使用 在 iOS 开发中&#xff0c;代码注释是一种很好的实践&#xff0c;可以帮助他人更容易理解你的代码。通常可以在代码中使用注释来解释代码的功能、目的、实现细节等。下面是一些常见的 iOS 代码注释示例&#xff1a; 1. 单行注释&#xff1a; // 这是一个…

数组方法汇总

数组和链表类似&#xff0c;都是用双指针&#xff0c;但数组不需要额外的指针&#xff0c;可以使用索引来当作指针。&#xff08;链表的时候要注意&#xff0c;什么时候是移动的指针&#xff0c;什么时候是改变的节点&#xff09;删除有序数组中的重复项 注意&#xff0c;本题中…