微信小程序自定義彈窗實(shí)現(xiàn)詳解(可通用)
本文為自定義彈窗,該內(nèi)容可滿足如下需求:
- 自定義各種布局彈窗
- 點(diǎn)擊彈窗布局外消失彈窗
- 彈出彈窗時背景陰影半透明
- 各方向彈出效果(本文為自下而上彈出)
話不多說,先上圖看效果:

點(diǎn)擊昵稱旁邊的編輯按鈕

彈出自定義彈窗
上圖是我自己拙劣的審美自定義的一個編輯彈窗,因?yàn)橹攸c(diǎn)是自定義彈窗,所以在下文的通用代碼中我就去掉了這些布局,剩下填充部分由讀者自行填充。
下面上代碼,老規(guī)矩,還是微信小程序?qū)?yīng)的幾個文件的代碼,可直接貼到頁面里用的哦。
.wxml 文件中 直接放到wxml的最底部就行了,十分簡練。
<view class="zan-dialog {{ showDialog ? 'zan-dialog--show' : '' }}">
<view class="zan-dialog__mask" bindtap="toggleDialog" />
<view class="zan-dialog__container">
<view style='padding:100rpx;'>此處是填充的布局代碼</view>
</view>
</view>
.wxss 文件中 直接放進(jìn)去就行,根據(jù)注釋可自行調(diào)節(jié)彈框帶不帶陰影。
.zan-dialog__mask {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
z-index: 10;
background: rgba(0, 0, 0, 0);//設(shè)置陰影半透明背景如: background: rgba(0, 0, 0, 0.4);
display: none;
}
.zan-dialog__container {
position: fixed;
bottom: 400rpx;
width: 650rpx;//彈窗布局寬
height: 350rpx;//彈窗布局高,與下面彈出距離transform有關(guān)
margin-left: 50rpx;
background: #f8f8f8;
transform: translateY(300%);//彈框彈出距離,與彈框布局高度有關(guān),如300%表示彈起距離為3倍彈窗高度
transition: all 0.4s ease;
z-index: 12;
border-radius: 20rpx;
box-shadow: 0px 3px 3px 2px gainsboro;//彈框的懸浮陰影效果,如不需要可注釋該行
}
.zan-dialog--show .zan-dialog__container {
transform: translateY(0);
}
.zan-dialog--show .zan-dialog__mask {
display: block;
}
.js 文件中 處理彈框彈出消失邏輯,以及自定義彈窗里的業(yè)務(wù)邏輯。
Page({
data: {
showDialog: false
},
/**
* 控制 pop 的打開關(guān)閉
* 該方法作用有2:
* 1:點(diǎn)擊彈窗以外的位置可消失彈窗
* 2:用到彈出或者關(guān)閉彈窗的業(yè)務(wù)邏輯時都可調(diào)用
*/
toggleDialog() {
this.setData({
showDialog: !this.data.showDialog
});
},
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
使用JavaScript制作待辦事項(xiàng)列表的示例代碼
這篇文章主要介紹了如何使用 JavaScript創(chuàng)建待辦事項(xiàng)列表HTML的完整信息和教程,文中但是示例代碼講解詳細(xì),感興趣的同學(xué)可以動手試一試2022-01-01
Javascript 實(shí)現(xiàn)放大鏡效果實(shí)例詳解
這篇文章主要介紹了Javascript 實(shí)現(xiàn)放大鏡效果實(shí)例詳解的相關(guān)資料,這里附有實(shí)現(xiàn)實(shí)例代碼,具有參考價值,需要的朋友可以參考下2016-12-12
JavaScript實(shí)現(xiàn)多層顏色選項(xiàng)卡嵌套
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)多層顏色選項(xiàng)卡嵌套,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-09-09
總結(jié)分享10個JavaScript代碼優(yōu)化小tips
這篇文章主要介紹了總結(jié)分享10個JavaScript代碼優(yōu)化小tips,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-07-07
JavaScript中不可忽略的Symbol的盤點(diǎn)
Symbol類型的出現(xiàn),為每個屬性賦予了獨(dú)一無二的標(biāo)識符,無論項(xiàng)目多么復(fù)雜,Symbol都能確保屬性鍵的絕對唯一性,下面我們就來看看JavaScript中那些不可忽略的Symbol吧2024-12-12
js獲取html頁面節(jié)點(diǎn)方法(遞歸方式)
這篇文章主要介紹了js使用遞歸方式獲取html頁面節(jié)點(diǎn)的方法,大家可以參考使用吧2013-12-12
基于JS實(shí)現(xiàn)checkbox全選功能實(shí)例代碼
最近做了個項(xiàng)目其中有這樣的需求要求實(shí)現(xiàn)點(diǎn)擊全選選中所有菜單,再次點(diǎn)擊全選取消選中。下面小編給大家分享實(shí)現(xiàn)代碼,對js實(shí)現(xiàn)checkbox全選功能感興趣的朋友參考下吧2016-10-10

