欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序使用component自定義toast彈窗效果

 更新時間:2018年11月27日 11:38:13   投稿:lijiao  
這篇文章主要介紹了微信小程序使用component自定義toast彈窗效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下

前言

微信小程序自帶的消息提示框有字數(shù)限制,而且圖標僅僅只有"success","loading","none"。當我們在實際開發(fā)過程中,面對UI給的設計圖稿和微信小程序默認提供的消息提示框具有很大差別的時候,自然就不能再使用微信小程序的消息提示框,而應當使用component自定義消息提示框組件。

效果圖

Step1:初始化組件

新建一個components文件夾,這個文件夾用來存放我們以后要開發(fā)的所有自定義組件。

然后在components文件夾中創(chuàng)建Toast文件夾,在Toast上右擊新建Component 之后就會自動創(chuàng)建相對應的wxml、wxss、js、json文件。

Step2:組件的相關配置

將toast.json 中component 設置為true

toast.json:

{
 "component": true,  // 自定義組件聲明
 "usingComponents": {}  // 可選項,用于引用別的組件
}

然后在toast.wxml文件里寫彈窗組件的模板,在toast.wxss文件里寫組件的樣式

toast.wxml:

<!--components/Toast/toast.wxml-->
<view class='mask' hidden="{{isShow}}">
 <image class="image" src='../../images/{{icon}}.png' mode='aspectFit'></image>
 <view class='info'>{{information}}</view>
</view>

toast.wxss:

/* components/Toast/toast.wxss */
.mask{
 width: 400rpx;
 height: 300rpx;
 border-radius:10rpx; 
 position: fixed;
 z-index: 1000;
 top: 300rpx;
 left: 175rpx;
 background: rgba(0, 0, 0, 0.6);
}
.image{
 z-index: 1000;
 width: 120rpx;
 height: 120rpx;
 margin-left: 140rpx;
}
.info{
 margin-top:50rpx; 
 z-index: 1000;
 text-align: center;
 color: #ffffff;
}
 width: 400rpx;
 height: 300rpx;
 border-radius:10rpx; 
 position: fixed;
 z-index: 1000;
 top: 300rpx;
 left: 175rpx;
 background: rgba(0, 0, 0, 0.6);
}
.image{
 z-index: 1000;
 width: 120rpx;
 height: 120rpx;
 margin-left:80rpx;
}
.info{
 margin-top:50rpx; 
 z-index: 1000;
 text-align: center;
 color: #ffffff;
}

Step3:定義屬性、數(shù)據(jù)和事件

可以看到在toast.wxml文件中出現(xiàn)了{{isShow}}、{{icon}}、{{information}} 變量,這是為了組件模板能夠根據(jù)傳入的屬性動態(tài)變化。

toast.js :

// components/Toast/toast.js
Component({
 /**
 * 組件的屬性列表
 */
 properties: {    //定義組件屬性
 information:{   //用來顯示提示信息
  type: String,   // 類型(必填),目前接受的類型包括:String, Number, Boolean, Object, Array, null(表示任意類型)
  value: '提示信息'  // 屬性初始值(可選),如果未指定則會根據(jù)類型選擇一個
 },
 icon:{     //圖標類型,我在images文件夾中存放了success和fail的兩個圖標
  type:String,
  value:'success'
 },
 showTime:{    //彈窗開始顯示的時間單位ms
  type: Number,
  value:1000
 },
 hideTime: {    //彈窗開始隱藏的時間單位ms
  type: Number,
  value: 1000
 }
 },
 /**
 * 組件的初始數(shù)據(jù)
 */
 data: {
 isShow:true
 },
 /**
 * 組件的方法列表
 */
 methods:{ 
 showToast:function () {
  let that = this;
  setTimeout(function () { 
  that.setData({
   isShow: !that.data.isShow
  });
  }, that.data.showTime);
 },
 hideToast: function (e) {
  let that = this;
  setTimeout(function(){  
  that.setData({
   isShow: !that.data.isShow
  });
  },that.data.hideTime);
 }
 }
})

Step4:使用彈窗/strong>

目前已經(jīng)完成了toast組件模板,接下來就是在需要顯示這個彈窗的頁面中使用它。

index.json:引入組件

{
 "usingComponents": {
 "toast": "/components/Toast/toast"
 }
}

index.wxml:

<!--page/index/index.wxml-->
<view class="container">
 <toast id='toast'information="提交成功,我們會盡快和您聯(lián)系" icon="success" showTime="1000" hideTime='2000'></toast>
 <button type="primary" bindtap="show"> 顯示彈窗 </button>
</view>

index.js:

// page/index/index.js
Page({
 /**
 * 頁面的初始數(shù)據(jù)
 */
 data: {

 },
 show:function(){
 this.toast.showToast();
 this.toast.hideToast();
 },
 /**
 * 生命周期函數(shù)--監(jiān)聽頁面加載
 */
 onLoad: function (options) {

 },
 /**
 * 生命周期函數(shù)--監(jiān)聽頁面初次渲染完成
 */
 onReady: function () {
 this.toast = this.selectComponent("#toast");
 },
 /**
 * 生命周期函數(shù)--監(jiān)聽頁面顯示
 */
 onShow: function () {

 },
 /**
 * 生命周期函數(shù)--監(jiān)聽頁面隱藏
 */
 onHide: function () {

 },
 /**
 * 生命周期函數(shù)--監(jiān)聽頁面卸載
 */
 onUnload: function () {

 },
 /**
 * 頁面相關事件處理函數(shù)--監(jiān)聽用戶下拉動作
 */
 onPullDownRefresh: function () {

 },
 /**
 * 頁面上拉觸底事件的處理函數(shù)
 */
 onReachBottom: function () {

 },
 /**
 * 用戶點擊右上角分享
 */
 onShareAppMessage: function () {

 }
})

至此我們就完成了自定義toast組件的步驟。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • JS檢測數(shù)組類型的方法小結(jié)

    JS檢測數(shù)組類型的方法小結(jié)

    這篇文章主要介紹了js檢測數(shù)組類型的方法小結(jié),有instanceof方法Array.isArray() 方法和Object.prototype.toString.call()方法,都是比較常用的,需要的朋友可以參考下
    2017-03-03
  • Js,alert出現(xiàn)亂碼問題的解決方法

    Js,alert出現(xiàn)亂碼問題的解決方法

    Js,alert出現(xiàn)亂碼問題的解決方法,需要的朋友可以參考一下
    2013-06-06
  • 詳解JavaScript中的原型和原型鏈

    詳解JavaScript中的原型和原型鏈

    這篇文章主要為大家介紹了JavaScript中的原型和原型鏈,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • Js控制彈窗實現(xiàn)在任意分辨率下居中顯示

    Js控制彈窗實現(xiàn)在任意分辨率下居中顯示

    彈窗居中比較煩人的是怎么才能在任意分辨率下實現(xiàn)居中顯示,為了解決此問題,本文測試了一下案例在此與大家分享,有類似需求的朋友可以學習下
    2013-08-08
  • 淺談Webpack 持久化緩存實踐

    淺談Webpack 持久化緩存實踐

    這篇文章主要介紹了淺談Webpack 持久化緩存實踐,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • javascript實現(xiàn)固定側(cè)邊欄

    javascript實現(xiàn)固定側(cè)邊欄

    這篇文章主要為大家詳細介紹了javascript實現(xiàn)固定側(cè)邊欄,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-02-02
  • JavaScript代碼性能優(yōu)化總結(jié)(推薦)

    JavaScript代碼性能優(yōu)化總結(jié)(推薦)

    下面小編就為大家?guī)硪黄狫avaScript代碼性能優(yōu)化總結(jié)(推薦)。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考,一起跟隨小編過來看看吧,祝大家游戲愉快哦
    2016-05-05
  • Javascript 學習書 推薦

    Javascript 學習書 推薦

    前一段時間看了一本javascript的書,書名為Javascript DOM 高級程序設計 由【加】Jeffrey Sambells和【美】
    2009-06-06
  • JS庫之ParticlesJS使用簡介

    JS庫之ParticlesJS使用簡介

    ParticlesJS是一個輕量級的創(chuàng)建粒子背景的 JavaScript 庫,接下來通過本文給大家分享JS庫之ParticlesJS使用簡介,感興趣的朋友一起看看吧
    2017-09-09
  • JS繼承實現(xiàn)方法及優(yōu)缺點詳解

    JS繼承實現(xiàn)方法及優(yōu)缺點詳解

    這篇文章主要介紹了JS繼承實現(xiàn)方法及優(yōu)缺點詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-09-09

最新評論