微信小程序登錄按鈕遮罩浮層效果的實(shí)現(xiàn)方法
前言
近期在寫(xiě)一點(diǎn)小東西,碰到遮罩...所以將實(shí)現(xiàn)的過(guò)程分享出來(lái),供大家參考學(xué)習(xí),下面話(huà)不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧
邏輯如下:
1:第一次登陸的時(shí)候會(huì)有一個(gè)登錄按鈕遮罩浮層提示去授權(quán)登錄
2:在彈出的授權(quán)框里,拒絕授權(quán)按鈕的時(shí)候,界面的數(shù)據(jù)沒(méi)有辦法加載出來(lái),允許授權(quán)的時(shí)候,界面就能渲染從后端拿過(guò)來(lái)的數(shù)據(jù)
3:判斷是否授過(guò)權(quán)(判斷是第一次登錄還是第n次),如果用戶(hù)第一次已經(jīng)登錄授權(quán),后面繼續(xù)登錄的時(shí)候懸浮框就不會(huì)再出現(xiàn)
效果如下:
代碼如下:
index.html
<!-- 授權(quán)彈框提示 --> <view class="container"> <view class="float" hidden='{{viewShowed}}'> <view class='floatContent'> <view class='floatText'> <text>獲取微信授權(quán)信息</text> <button open-type="getUserInfo" bindgetuserinfo="getUserInfo">去設(shè)置</button> </view> </view> </view> </view>
index.wxss
.float { height: 100%; width: 100%; position: fixed; background-color: rgba(0, 0, 0, 0.5); z-index: 2; top: 0; left: 0; } .floatContent { padding: 20rpx 0; width: 80%; background: #fff; margin: 40% auto; border-radius: 20rpx; display: flex; flex-direction: column; justify-content: space-around; align-items: center; position: relative; height: 332rpx; } .floatText text { color: #000; font-size: 40rpx; display: block; text-align: center; line-height: 90rpx; border-radius: 30rpx; margin-right: 10rpx; }
index.js
js代碼,與后臺(tái)數(shù)據(jù)庫(kù)交互,授權(quán)的信息存入了數(shù)據(jù)庫(kù),可根據(jù)自己的需要做出相應(yīng)的修改。
//index.js //獲取應(yīng)用實(shí)例 var app = getApp() Page({ data: { carList: [], //車(chē)輛數(shù)據(jù)集合 viewShowed: true, //控制授權(quán)是否顯示 }, onLoad: function () { var that = this; app.getOpenid().then(function (res) { if (res.status == 200) { //判斷是否授權(quán) wx.getSetting({ success(e) { if (e.authSetting['scope.userInfo']) { //已經(jīng)授權(quán) that.getCars(res.data); } else { //沒(méi)有授權(quán),顯示授權(quán)框 that.setData({ viewShowed: false, }) } } }) } }) }, getUserInfo: function (e) { var that = this; that.setData({ viewShowed: true, }); var userinfo = e.detail.userInfo; wx.request({ url: "http://localhost:8081/wpDeboServer/wx.do", data: { "openid": app.globalData.openid, "nickname": userinfo.nickName }, method: 'PUT', header: { 'Content-type': 'application/json' }, success: function (res) { //查詢(xún)綁定車(chē)輛 that.getCars(app.globalData.openid); } }); }, })
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
鍵盤(pán)上下鍵移動(dòng)選擇table表格行的js代碼
通過(guò)鍵盤(pán)上的上下鍵可以選擇表格行的實(shí)現(xiàn)效果代碼。思路不錯(cuò),需要的朋友可以參考下。2009-12-12詳解JS中的compose函數(shù)和pipe函數(shù)用法
這篇文章主要介紹了JS中的compose函數(shù)和pipe函數(shù)用法,想深入了解Javascript的同學(xué),可以參考下2021-04-04js代碼延遲一定時(shí)間后執(zhí)行一個(gè)函數(shù)的實(shí)例
下面小編就為大家?guī)?lái)一篇js代碼延遲一定時(shí)間后執(zhí)行一個(gè)函數(shù)的實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02HTML中使背景圖片自適應(yīng)瀏覽器大小實(shí)例詳解
這篇文章主要介紹了HTML中使背景圖片自適應(yīng)瀏覽器大小實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-04-04使用JavaScript switch case 另類(lèi)寫(xiě)法
在JavaScript里,函數(shù)(todoA、todoB、todoC)就是對(duì)象,“()”的作用就是就是執(zhí)行函數(shù)對(duì)象,二者簡(jiǎn)單地組合一下就能夠讓代碼清晰簡(jiǎn)潔很多了,何樂(lè)不為呢?2010-03-03JS實(shí)現(xiàn)太極旋轉(zhuǎn)思路分析
本文主要對(duì)JS實(shí)現(xiàn)太極旋轉(zhuǎn)的思路進(jìn)行分析,步驟清晰,簡(jiǎn)短的文字,深入的理解。需要的朋友可以看下2016-12-12小程序云開(kāi)發(fā)實(shí)現(xiàn)數(shù)據(jù)庫(kù)異步操作同步化
這篇文章主要為大家詳細(xì)介紹了小程序云開(kāi)發(fā)實(shí)現(xiàn)數(shù)據(jù)庫(kù)異步操作同步化,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-05-05