微信小程序自定义弹窗,Loading

页面引用

<button type='button' bindtap='click'>点击</button>
<import src='../../template/template.wxml'/>
<template is='toast' data='{{...toast}}'></template>
<template is='loading' data='{{...loading}}'></template>

调用

// pages/animate/animate.js
import api from '../../utils/util.js';
Page({

    /**
     * 页面的初始数据
     */
    data: {
        toast: {
            flag: '',
            msg: '',
            show: true
        },
        loading: {
            msg: '',
            show: true
        }
    },
    click: function() {
        var that = this;
        // api.Toast(1, '提交成功', that, 20000);
        // api.Toast(2, '提交失败', that, 20000);
        api.Loading('提交失败', that);
        setTimeout(()=>{
            api.Close(that);
        },5000);
    }
})

template.wxml

<template name='toast'>
    <cover-view class="Toast" hidden="{{show}}">
        <cover-view class='ToastBg'></cover-view>
        <cover-view class='mask' wx:if='{{flag==1}}'>
            <cover-view class='icon'>
                <cover-image src='../../img/success.png' class='image'></cover-image>
            </cover-view>
            <cover-view class='msg'>{{msg}}</cover-view>
        </cover-view>

        <cover-view class='mask' wx:elif='{{flag==2}}'>
            <cover-view class='icon'>
                <cover-image src='../../img/fail.png' class='image'></cover-image>
            </cover-view>
            <cover-view class='msg'>{{msg}}</cover-view>
        </cover-view>
    </cover-view>
</template>
<template name='loading'>
    <cover-view class="Toast" hidden="{{show}}">
        <cover-view class='ToastBg'></cover-view>
        <cover-view class='mask'>
            <cover-view class='icon'>
                <cover-view class='loading_icon'></cover-view>
            </cover-view>
            <cover-view class='msg'>{{msg}}</cover-view>
        </cover-view>
    </cover-view>
</template>

utils.js

var app = getApp();
var baseUrl = getApp().baseUrl;
//开启toast
// flag(1表示成功,2表示失败,msg表示自定义提示信息,time提示显示时长);
var Toast = (flag, msg, that, time) => {
    that.data.toast.flag = flag;
    that.data.toast.msg = msg;
    that.data.toast.show = false;
    that.setData({
        toast: that.data.toast,
    })
    if(time){
        setTimeout(function () {
            that.data.toast.show = true;
            that.setData({
                toast: that.data.toast,
            }) //1.5秒之后弹窗隐藏
        }, time)
    }
}
//开启loading
var Loading = (msg, that) => {
    that.data.loading.msg = msg;
    that.data.loading.show = false;
    that.setData({
        loading: that.data.loading,
    })
}
//关闭loading
var Close = (that)=>{
    that.data.loading.msg = '';
    that.data.loading.show = true;
    that.setData({
        loading: that.data.loading,
    })
}
module.exports = {
    Toast: Toast,
    Loading: Loading,
    Close: Close
}

弹窗wxss

.Toast {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: transparent;
    /* background: rgba(255,255,255,1); */
    z-index: 99999;
}

.Toast .mask {
    padding: 20rpx 30rpx;
    background: rgba(0, 0, 0, 0.7);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    align-items: center;
    border-radius: 6rpx;
    box-sizing: border-box;
    max-width: 70%;
    z-index: 2;
}

.Toast .mask .icon {
    margin-right: 20rpx;
}

.Toast .mask .icon .image {
    width: 60rpx;
    height: 60rpx;
}

.Toast .mask  .msg {
    flex: 1;
    color: #fff;
    line-height: 40rpx;
    font-size: 28rpx;
    white-space: pre-wrap;
}

.ToastBg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: transparent;
    z-index: 1;
}

.loading_icon{
    -webkit-animation: loading 1s steps(12, end) infinite;
    animation: loading 1s steps(12, end) infinite;
    background: transparent url() no-repeat;
    background-size: 100%;
    width: 80rpx;
    height: 80rpx;
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值