国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 課堂 > 小程序 > 正文

微信小程序封裝自定義彈窗的實(shí)現(xiàn)代碼

2020-03-21 15:57:14
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

 最近在做小程序的登錄,需要同時(shí)獲取用戶(hù)手機(jī)號(hào)和頭像昵稱(chēng)等信息,但是小程序又不支持單個(gè)接口同時(shí)獲取兩種數(shù)據(jù),因此想到自定義一個(gè)彈窗,通過(guò)彈窗按鈕觸發(fā)獲取手機(jī)號(hào)事件。記錄一下。

微信小程序,封裝,彈窗,代碼

具體代碼如下:

業(yè)務(wù)代碼中:

  在業(yè)務(wù)代碼中引入dialog組件即可

<dialog visible="{{dialogVisible}}" showFooter="{{footerVisible}}" style="margin: 0px; padding: 0px; outline: none; line-height: 25.2px; font-size: 14px; width: 660px; overflow: hidden; clear: both; font-family: tahoma, arial, "Microsoft YaHei";">	
<!--components/dialog/dialog.wxml--><view class='dialog-custom' wx:if="{{visible}}">  <view class='dialog-mask' bindtap="clickMask"></view>    <view class="dialog-main">      <view class="dialog-container">        <view class='dialog-container__title' wx:if="{{title.length>0}}">          <view class='title-label'>{{ title }}</view>          <view class='title-icon'>            <image wx:if="{{showClose}}" bindtap='close' src='/images/close-btn.png'></image>          </view>        </view>      <view class='dialog-container__body'>        <slot name="dialog-body"></slot>      </view>      <view class='dialog-container__footer' wx:if="{{showFooter}}">        <view class='dialog-container__footer__cancel' bindtap="close">取消</view>        <view class='dialog-container__footer__confirm' bindtap='confirm'>確定</view>      </view>    </view>  </view></view>

dialog.js

 

Component({/*** 組件的屬性列表*/properties: {  visible: {    type: Boolean,    value: false  },  width: {    type: Number,    value: 85  },  position: {    type: String,    value: 'center'  },  title: {    type: String,    value: ''  },  showClose: {    type: Boolean,    value: true  },  showFooter: {    type: Boolean,    value: false  },},/*** 組件的初始數(shù)據(jù)*/data: {},options:{  multipleSlots: true},/*** 組件的方法列表*/methods: {  clickMask() {    this.setData({ visible: false });  },  close(){    this.setData({ visible: false });  },  cancel() {    this.setData({ visible: false });    this.triggerEvent('cancel');  },  confirm() {    this.setData({ visible: false });    this.triggerEvent('confirm');  }}})

dialog.json:聲明是組件就行 

{  "component": true,  "usingComponents": {}}

dialog.wxss

  css可以根據(jù)自己喜好的樣式調(diào)整,注意mask遮罩層的z-index高一點(diǎn),確保在最上層

/* components/dialog/dialog.wxss */.dialog-custom {  width: 100vw;  height: 100%;  position: absolute;  left: 0;  top: 0;  z-index: 9999;}.dialog-mask {  position: fixed;  top: 0;  left: 0;  right: 0;  bottom: 0;  z-index: 10000;  width: 100vw;  height: 100%;  background: rgba(0, 0, 0, 0.3);}.dialog-main {  position: fixed;  z-index: 10001;  top: 50%;  left: 0;  right: 0;  width: 85vw;  height: auto;  margin: auto;  transform: translateY(-50%);}.dialog-container {  margin: 0 auto;  background: #fff;  z-index: 10001;  border-radius: 3px;  box-sizing: border-box;  padding: 40rpx;}.dialog-container__title {  width: 100%;  height: 50rpx;  line-height: 50rpx;  margin-bottom: 20rpx;  position: relative;}.dialog-container__title .title-label{  display: inline-block;  width: 100%;  height: 50rpx;  line-height: 50rpx;  font-size: 36rpx;  color: #000;  text-align: center;}.dialog-container__title .title-icon{  width: 34rpx;  height: 50rpx;  position: absolute;  top: 0;  right: 0;}.dialog-container__title .title-icon image{  width: 34rpx;  height: 34rpx;}.dialog-container__body {  padding-top: 10rpx;  font-size: 32rpx;  line-height: 50rpx;}.dialog-container__footer {  height: 76rpx;  line-height: 76rpx;  font-size: 32rpx;  text-align: center;  border-top: 1px solid #f1f1f1;  position: absolute;  bottom: 0;  left: 0;  right: 0;}.dialog-container__footer .dialog-container__footer__cancel {  width: 50%;  color: #999;  display: inline-block;}.dialog-container__footer .dialog-container__footer__cancel::after{  position: absolute;  right: 50%;  bottom: 0;  content: '';  width: 2rpx;  height: 76rpx;  background: #f1f1f1;}.dialog-container__footer .dialog-container__footer__confirm {  color: #3B98F7;  width: 50%;  display: inline-block;  text-align: center;}

 

/* components/dialog/dialog.wxss */.dialog-custom {width: 100vw;height: 100%;position: absolute;left: 0;top: 0;z-index: 9999;}.dialog-mask {position: fixed;top: 0;left: 0;right: 0;bottom: 0;z-index: 10000;width: 100vw;height: 100%;background: rgba(0, 0, 0, 0.3);}.dialog-main {position: fixed;z-index: 10001;top: 50%;left: 0;right: 0;width: 85vw;height: auto;margin: auto;transform: translateY(-50%);}.dialog-container {margin: 0 auto;background: #fff;z-index: 10001;border-radius: 3px;box-sizing: border-box;padding: 40rpx;}.dialog-container__title {width: 100%;height: 50rpx;line-height: 50rpx;margin-bottom: 20rpx;position: relative;}.dialog-container__title .title-label{display: inline-block;width: 100%;height: 50rpx;line-height: 50rpx;font-size: 36rpx;color: #000;text-align: center;}.dialog-container__title .title-icon{width: 34rpx;height: 50rpx;position: absolute;top: 0;right: 0;}.dialog-container__title .title-icon image{width: 34rpx;height: 34rpx;}.dialog-container__body { padding-top: 10rpx; font-size: 32rpx; line-height: 50rpx;}.dialog-container__footer { height: 76rpx; line-height: 76rpx; font-size: 32rpx; text-align: center; border-top: 1px solid #f1f1f1; position: absolute; bottom: 0; left: 0; right: 0;}.dialog-container__footer .dialog-container__footer__cancel { width: 50%; color: #999; display: inline-block;}.dialog-container__footer .dialog-container__footer__cancel::after{ position: absolute; right: 50%; bottom: 0; content: ''; width: 2rpx; height: 76rpx; background: #f1f1f1;}.dialog-container__footer .dialog-container__footer__confirm { color: #3B98F7; width: 50%; display: inline-block; text-align: center;}

總結(jié)

以上所述是小編給大家介紹的微信小程序封裝自定義彈窗的實(shí)現(xiàn)代碼,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)VEVB武林網(wǎng)網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!


發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 合阳县| 雅安市| 吴桥县| 顺义区| 新竹县| 光山县| 乐东| 济南市| 甘肃省| 维西| 孝义市| 开江县| 长寿区| 南宁市| 社旗县| 象山县| 丁青县| 衡阳市| 金华市| 宁强县| 沈丘县| 长阳| 海淀区| 新化县| 新源县| 长垣县| 普洱| 兰西县| 中牟县| 凤凰县| 中牟县| 漳平市| 凤庆县| 铁岭县| 桦甸市| 汶川县| 莱阳市| 乌苏市| 陈巴尔虎旗| 广宁县| 大新县|