Rumah > applet WeChat > Pembangunan program mini > 微信小程序自定义toast实现方法详解

微信小程序自定义toast实现方法详解

小云云
Lepaskan: 2017-12-07 15:53:11
asal
2948 orang telah melayarinya

前面我们分享过很多关于微信小程序教程,本文我们主要介绍微信小程序自定义toast实现方法,简单描述了微信小程序自带toast使用方法,并结合实例形式分析了自定义toast的定义与使用方法,需要的朋友可以参考下。

一、微信官方默认toast

toast最常见了,几乎每个App都有这样的特效,先看下小程序自带的toast效果,立马想死的心都有了~~

微信自带toast的效果:

js文件:


wx.showToast({
 title: '成功',
 icon: 'success',
 duration: 2000
})
Salin selepas log masuk


用法超级简单,但官方小程序有几个问题:

只能显示success、loading两种icon

且icon不可去除

持续时间最大10秒

二、自定义toast

我们最常见的toast是偏底部,而且高度是比较小的那种~~

先看效果:

看似简单,实现起来相当不简单,如何实现:

1)建立一个公共的toast的template模板文件,因为每个页面都需要用到toast


<!-- wetoast.wxml -->
<template name="wetoast">
 <view class="wetoast {{reveal ? &#39;wetoast_show&#39; : &#39;&#39;}}">
  <view class="wetoast__mask"></view>
  <view class="wetoast__bd {{position}}" animation="{{animationData}}">
   <block wx:if="{{title}}">
    <view class="wetoast__bd__title {{titleClassName || &#39;&#39;}}">{{title}}</view>
   </block>
  </view>
 </view>
</template>
Salin selepas log masuk


2)JS主要有以下用法

核心代码:


let pages = getCurrentPages();
let curPage = pages[pages.length - 1];
Salin selepas log masuk


这段代码是核心,getCurrentPages().length - 1 表示可以获得当前页面的page,只有获得了page,才能通过page.setData把当前页面的数据绑定到toast上面。

核心代码:


let animation = wx.createAnimation();
animation.opacity(1).step();
Salin selepas log masuk


这段代码是toast消失的时候有一个缓慢的动画效果。

相关推荐:

微信小程序slider组件动态修改标签透明度的方法

微信小程序如何实现图片放大预览功能

微信小程序分享时可自定义配图新功能

Atas ialah kandungan terperinci 微信小程序自定义toast实现方法详解. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan