微信小程序?qū)崿F(xiàn)自定義彈窗組件的示例代碼
上一篇中說(shuō)的是小程序自帶的彈窗組件,今天,我們來(lái)試試小程序的自定義組件,我們自定義一個(gè)帶確定取消的彈窗組件。
首先,放一下,最終的效果圖:

這是我們最后要實(shí)現(xiàn)的效果
那么,首先,我們創(chuàng)建一個(gè)組件
新建component文件夾存放我們的組件,里邊存放的就是我們所用的組件,我們今天要做的事彈出框,新建文件夾popup存放我們的組件模板,點(diǎn)擊右鍵選擇新建component,就會(huì)自動(dòng)生成組件的模板wxss、wxml、json、js,如圖

剩下的,就是不廢話了,上代碼:
編寫(xiě)組件代碼
Dialog.wxml
<view class="wx-popup" hidden="{{flag}}">
<view class='popup-container'>
<view class="wx-popup-title">{{title}}</view>
<view class="wx-popup-con">{{content}}</view>
<view class="wx-popup-btn">
<text class="btn-no" bindtap='_error'>{{btn_no}}</text>
<text class="btn-ok" bindtap='_success'>{{btn_ok}}</text>
</view>
</view>
</view>
Dialog.js
Component({
options: {
multipleSlots: true // 在組件定義時(shí)的選項(xiàng)中啟用多slot支持
},
/**
* 組件的屬性列表
*/
properties: {
title: { // 屬性名
type: String, // 類(lèi)型(必填),目前接受的類(lèi)型包括:String, Number, Boolean, Object, Array, null(表示任意類(lèi)型)
value: '標(biāo)題' // 屬性初始值(可選),如果未指定則會(huì)根據(jù)類(lèi)型選擇一個(gè)
},
// 彈窗內(nèi)容
content: {
type: String,
value: '內(nèi)容'
},
// 彈窗取消按鈕文字
btn_no: {
type: String,
value: '取消'
},
// 彈窗確認(rèn)按鈕文字
btn_ok: {
type: String,
value: '確定'
}
},
/**
* 組件的初始數(shù)據(jù)
*/
data: {
flag: true,
},
/**
* 組件的方法列表
*/
methods: {
//隱藏彈框
hidePopup: function () {
this.setData({
flag: !this.data.flag
})
},
//展示彈框
showPopup () {
this.setData({
flag: !this.data.flag
})
},
/*
* 內(nèi)部私有方法建議以下劃線開(kāi)頭
* triggerEvent 用于觸發(fā)事件
*/
_error () {
//觸發(fā)取消回調(diào)
this.triggerEvent("error")
},
_success () {
//觸發(fā)成功回調(diào)
this.triggerEvent("success");
}
}
})
Dialog.wxss
/* component/popup.wxss */
.wx-popup {
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, .5);
}
.popup-container {
position: absolute;
left: 50%;
top: 50%;
width: 80%;
max-width: 600rpx;
border: 2rpx solid #ccc;
border-radius: 10rpx;
box-sizing: bordre-box;
transform: translate(-50%, -50%);
overflow: hidden;
background: #fff;
}
.wx-popup-title {
width: 100%;
padding: 20rpx;
text-align: center;
font-size: 40rpx;
border-bottom: 2rpx solid red;
}
.wx-popup-con {
margin: 60rpx 10rpx;
text-align: center;
}
.wx-popup-btn {
display: flex;
justify-content: space-around;
margin-bottom: 40rpx;
}
.wx-popup-btn text {
display: flex;
align-items: center;
justify-content: center;
width: 30%;
height: 88rpx;
border: 2rpx solid #ccc;
border-radius: 88rpx;
}
組件的代碼,到這里就是完成了。
調(diào)用自定義組件
1:我們要在留言板中使用這個(gè)自定義組件,打開(kāi)board.json,在usingComponents中增加如下代碼
"popup": "/component/popup/popup";
2:在board.wxml中引入組件
<!—自定義組件-->
<view class="container">
<view class="userinfo">
<button bindtap="showPopup"> 點(diǎn)我 </button>
</view>
<popup id='popup'
title='小組件'
content='學(xué)會(huì)了嗎'
btn_no='沒(méi)有'
btn_ok='學(xué)會(huì)了'
bind:error="_error"
bind:success="_success">
</popup>
</view>
3:在board.js中調(diào)用組件
//獲取應(yīng)用實(shí)例
const app = getApp()
Page({
onReady: function () {
//獲得popup組件
this.popup = this.selectComponent("#popup");
},
showPopup() {
this.popup.showPopup();
},
//取消事件
_error() {
console.log('你點(diǎn)擊了取消');
this.popup.hidePopup();
},
//確認(rèn)事件
_success() {
console.log('你點(diǎn)擊了確定');
this.popup.hidePopup();
}
})
至此,一個(gè)簡(jiǎn)單的自定義組件的封裝及調(diào)用都完成了。
以上就是微信小程序?qū)崿F(xiàn)自定義彈窗組件的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于微信小程序彈窗組件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
js實(shí)現(xiàn)倒計(jì)時(shí)器自定義時(shí)間和暫停
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)倒計(jì)時(shí)器自定義時(shí)間和暫停,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-02-02
javascript模擬的Ping效果代碼 (Web Ping)
JS雖然發(fā)送不了真正Ping的ICMP數(shù)據(jù)包,但Ping的本質(zhì)仍然是請(qǐng)求/回復(fù)的時(shí)間差,HTTP自然可以實(shí)現(xiàn)此功能.2011-03-03
Uniapp實(shí)現(xiàn)地圖獲取定位功能(推薦)
本文詳細(xì)介紹了如何在Uniapp項(xiàng)目中集成地圖功能,實(shí)現(xiàn)定位獲取,并解決微信小程序、APP、H5三端的兼容性問(wèn)題,涵蓋了環(huán)境準(zhǔn)備、配置地圖基礎(chǔ)功能、獲取用戶(hù)定位、多平臺(tái)適配要點(diǎn)以及常見(jiàn)問(wèn)題及解決方案,感興趣的朋友一起看看吧2025-03-03
淺析原生JavaScript中拖拽屬性draggable的使用
這篇文章主要為大家詳細(xì)介紹了原生JavaScript中拖拽屬性draggable使用的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-03-03
詳解JavaScript基于面向?qū)ο笾^承實(shí)例
這篇文章主要介紹了JavaScript基于面向?qū)ο笾^承實(shí)例,需要的朋友可以參考下2015-12-12
微信小程序swiper-dot中的點(diǎn)如何改成滑塊詳解
swiper組件是滑塊視圖容器,這篇文章主要給大家介紹了關(guān)于微信小程序swiper-dot中的點(diǎn)如何改成滑塊的相關(guān)資料,實(shí)現(xiàn)以后的效果還是不錯(cuò)的,需要的朋友可以參考下2021-07-07
JavaScript實(shí)現(xiàn)AOP詳解(面向切面編程,裝飾者模式)
下面小編就為大家分享一篇JavaScript實(shí)現(xiàn)AOP的方法(面向切面編程,裝飾者模式),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12

