小程序開發(fā)之模態(tài)框組件封裝
本文實例為大家分享了小程序模態(tài)框組件的封裝具體代碼,供大家參考,具體內(nèi)容如下
一、前言
對于模態(tài)框肯定大家都知道,諸如:Bootstartp、element-ui、layui等等都有自己的彈出層,并可以之定義內(nèi)容,但是小程序的彈出層原生的太簡單,那么我們?nèi)绻远x呢?
其實很簡單,就是一個遮罩、一個view內(nèi)容區(qū)就搞定了!接下來看一下我自己封裝后的模態(tài)框效果:
感覺還可以哈!
二、模態(tài)框組件的使用
1.先在使用頁面的json注冊該組件
{ "navigationBarTitleText": "XXXX", "usingComponents": { "print-popups": "/components/popups/popups" } }
2.使用組件
<view> <print-popups ifOpen='{{modelStatus}}' bind:ifClose='closeModel'> <view slot='popups_main' class='popups_main'> <view class='popups_item'>添加新設(shè)備</view> <view class='popups_item print_name'> <input class='print_input' value='設(shè)備1' auto-focus /> <view class='print_tip'>(點擊設(shè)備可編輯)</view> </view> <view class='popups_item print_id'> <input placeholder="請輸入新添設(shè)備ID" /> <view class='print_id_check'>可用</view> </view> <button class='popups_item print_btn' type='primary' size='mini'>添加</button> </view> </print-popups> </view>
3.添加隱藏/顯示方法
Page({ /** * 頁面的初始數(shù)據(jù) */ data: { modelStatus: false }, /** * 點擊按鈕打開模態(tài)框 */ openModel () { const modelStatus = !this.modelStatus this.setData({ modelStatus}) }, /** * 子組件觸發(fā)的事件 */ closeModel (event) { console.log(event.detail.value) this.setData({ modelStatus: event.detail.value }) } })
三、模態(tài)框組件源碼
1.Json文件
{ "component": true, "usingComponents": {} }
2.wxml文件
需要在阿里圖標(biāo)庫找一張close.png的圖片。
<!--components/popups/popups.wxml--> <view wx:if="{{ifOpen}}"> <view class='popups_shade' bindtap='popupsClose'></view> <view class='popups_content'> <image src='./images/close.png' class='popups_close' bindtap='popupsClose'></image> <slot name='popups_main'/> </view> </view>
3.wxss文件
/* components/popups/popups.wxss */ /* 遮罩 */ .popups_shade { width: 100%; height: 100%; position: fixed; top: 0; left: 0; z-index: 1000; background: #000; opacity: 0.7; overflow: hidden; } /* 彈出層內(nèi)容 */ .popups_content { width: 500rpx; height: 350rpx; overflow: hidden; position: fixed; top: 0px; left: 0px; bottom: 0px; right: 0px; margin: auto; z-index: 1001; background: #FAFAFA; border-radius: 5px; } .popups_close { width: 30rpx; height: 30rpx; position: absolute; right: 3px; top: 3px; }
4.js文件
// components/popups/popups.js Component({ options: { multipleSlots: true }, /** * 組件的屬性列表 */ properties: { ifOpen: Boolean }, /** * 組件的初始數(shù)據(jù) */ data: { }, /** * 父子組件通信 * 組件的方法列表 */ methods: { popupsClose () { console.log('關(guān)閉彈出層' + this.properties.ifOpen) this.triggerEvent('ifClose', { value: !this.properties.ifOpen}) } } })
四、思路
主要是使用slot插槽可以不需要定義內(nèi)容,可以在使用組件的頁面自定義,這樣就可以很好提高擴(kuò)展性!
為大家推薦現(xiàn)在關(guān)注度比較高的微信小程序教程一篇:《微信小程序開發(fā)教程》小編為大家精心整理的,希望喜歡。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
網(wǎng)頁右鍵ie不支持event.preventDefault和event.returnValue (需要加window)
網(wǎng)頁右鍵ie不支持event.preventDefault和event.returnValue (需要加window) ,需要的朋友可以參考一下2013-02-02基于javascript的COOkie的操作實現(xiàn)只能點一次
這篇文章主要介紹了基于javascript的COOkie的操作實現(xiàn)只能點一次,需要的朋友可以參考下2014-12-12顏色選擇器 Color Picker,IE,Firefox,Opera,Safar
顏色選擇器 Color Picker,需要的朋友可以參考下。2010-11-11