data:image/s3,"s3://crabby-images/47861/4786109cb291879f855bfc0d79243297c388e702" alt="【移動(dòng)應(yīng)用開發(fā)技術(shù)】微信小程序中input輸入及動(dòng)態(tài)設(shè)置按鈕的實(shí)現(xiàn)方法_第1頁"
data:image/s3,"s3://crabby-images/025d2/025d27f8c418bb6e8ca47ab876dd950a5b4fb900" alt="【移動(dòng)應(yīng)用開發(fā)技術(shù)】微信小程序中input輸入及動(dòng)態(tài)設(shè)置按鈕的實(shí)現(xiàn)方法_第2頁"
data:image/s3,"s3://crabby-images/38158/3815838fd0525f63f07031628c4959712a947f23" alt="【移動(dòng)應(yīng)用開發(fā)技術(shù)】微信小程序中input輸入及動(dòng)態(tài)設(shè)置按鈕的實(shí)現(xiàn)方法_第3頁"
data:image/s3,"s3://crabby-images/15fbf/15fbf9a1680a6c3ff8b2bb838290013de11dd987" alt="【移動(dòng)應(yīng)用開發(fā)技術(shù)】微信小程序中input輸入及動(dòng)態(tài)設(shè)置按鈕的實(shí)現(xiàn)方法_第4頁"
data:image/s3,"s3://crabby-images/bfa0b/bfa0baf330a71e61c99acd07a43215d36f0dbb88" alt="【移動(dòng)應(yīng)用開發(fā)技術(shù)】微信小程序中input輸入及動(dòng)態(tài)設(shè)置按鈕的實(shí)現(xiàn)方法_第5頁"
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
【移動(dòng)應(yīng)用開發(fā)技術(shù)】微信小程序中input輸入及動(dòng)態(tài)設(shè)置按鈕的實(shí)現(xiàn)方法
這篇文章給大家分享的是有關(guān)微信小程序中input輸入及動(dòng)態(tài)設(shè)置按鈕的實(shí)現(xiàn)方法的內(nèi)容。在下覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨在下過來看看吧。微信小程序input輸入及動(dòng)態(tài)設(shè)置按鈕的實(shí)現(xiàn)【需求】實(shí)現(xiàn)當(dāng)手機(jī)號(hào)已填寫和協(xié)議已勾選時(shí),“立即登錄”按鈕變亮,按鈕可點(diǎn)擊;若有一個(gè)不滿足,按鈕置灰,不可點(diǎn)擊;實(shí)現(xiàn)獲取短信驗(yàn)證碼,倒計(jì)時(shí)提示操作;對(duì)不滿足要求內(nèi)容進(jìn)行toast彈窗提示。<view
class="container">
<!--手機(jī)號(hào)-->
<view
class="section">
<text
class="txt">手機(jī)號(hào)</text>
<input
value="{{mobile}}"
placeholder-class="placeholder"
placeholder="11位手機(jī)號(hào)碼"
type="number"
maxlength="11"
bindinput="mobileInput"/>
</view>
<!--圖片驗(yàn)證碼-->
<view
class="section">
<view>
<text
class="txt">圖形驗(yàn)證碼</text>
<input
placeholder-class="placeholder"
placeholder="輸入圖形驗(yàn)證碼"
type="text"
maxlength="4"
bindinput="imgCaptchaInput"/>
</view>
<image
class="imgBtn"
src="{{imgCodeSrc}}"
bindtap="getImgCode"></image>
</view>
<!--短信驗(yàn)證碼-->
<view
class="section">
<view>
<text
class="txt">驗(yàn)證碼</text>
<input
placeholder-class="placeholder"
placeholder="輸入驗(yàn)證碼"
type="number"
maxlength="6"
bindinput="smsCaptchaInput"/>
</view>
<view
class="smsBtn"
bindtap="getSMS">{{captchaText}}</view>
</view>
<view
class="agree"
style="margin-top:40rpx">
<checkbox-group
bindchange="checkboxChange">
<checkbox
class="check"
value="1"
checked="true"
bindchange="checkboxChange"></checkbox>
</checkbox-group>
<span>已閱讀并同意</span>
<text
style="color:#98c7ff"
bindtap="xieyi">《用戶使用協(xié)議》</text>
</view>
<view
class="regist
{{phoneAll&&checkAgree?'active':''}}"
bindtap="regist">立即登錄</view>
</view>
<!--mask-->
<view
class="toast_mask"
wx:if="{{isShowToast}}"></view>
<!--以下為toast顯示的內(nèi)容-->
<view
class="toast_content_box"
wx:if="{{isShowToast}}">
<view
class="toast_content">
<view
class="toast_content_text">
{{toastText}}
</view>
</view>
</view>js//
獲取全局應(yīng)用程序?qū)嵗龑?duì)象
const
app
=
getApp()
Page({
data:
{
//toast默認(rèn)不顯示
isShowToast:
false,
mobile:
'',
imgCode:
'',
code:
'',
//
inviteCode:
'',
errorContent:
'請(qǐng)輸入手機(jī)號(hào)',
timer:
60,
captchaText:
'獲取驗(yàn)證碼',
captchaSended:
false,
isReadOnly:
false,
capKey:
'',
sendRegist:
false,
imgCodeSrc:
'',
phoneAll:
false,
checkAgree:true,
checkboxValue:[1],
},
//
顯示彈窗
showToast(txt,
duration
=
1500)
{
//設(shè)置toast時(shí)間,toast內(nèi)容
this.setData({
count:
duration,
toastText:
txt
});
var
_this
=
this;
//
toast時(shí)間
_this.data.count
=
parseInt(_this.data.count)
?
parseInt(_this.data.count)
:
3000;
//
顯示toast
_this.setData({
isShowToast:
true,
});
//
定時(shí)器關(guān)閉
setTimeout(function
()
{
_this.setData({
isShowToast:
false
});
},
_this.data.count);
},
//
雙向綁定mobile
mobileInput(e)
{
this.setData({
mobile:
e.detail.value
});
if(this.data.mobile.length===11){
this.setData({
phoneAll:
true
});
}else
if(this.data.mobile.length<11){
this.setData({
phoneAll:
false
});
}
},
//
雙向綁定img驗(yàn)證碼
imgCaptchaInput(e)
{
this.setData({
imgCode:
e.detail.value
});
},
//
雙向綁定sms驗(yàn)證碼
smsCaptchaInput(e)
{
this.setData({
code:
e.detail.value
});
},
//
同意協(xié)議
checkboxChange(e)
{
this.data.checkboxValue
=
e.detail.value;
if(this.data.checkboxValue[0]==1){
this.setData({
checkAgree:
true
});
}else
{
this.setData({
checkAgree:
false
});
}
},
//
獲取短信驗(yàn)證碼
getSMS()
{
var
that
=
this.data;
if
(!that.mobile)
{
this.showToast('請(qǐng)輸入手機(jī)號(hào)');
}
else
if
(that.mobile.length
!=
11
||
isNaN(that.mobile))
{
this.showToast('請(qǐng)輸入正確手機(jī)號(hào)');
}
else
if
(that.imgCode.length
!=
4)
{
this.showToast('請(qǐng)輸入正確圖片驗(yàn)證碼');
}
else
{
if
(that.captchaSended)
return;
this.setData({
captchaSended:
true
})
app.api.getSMSByMobileAndCaptcha({
mobile:
that.mobile,
capKey:
that.capKey,
code:
that.imgCode,
type:1
}).then((result)
=>
{
this.showToast(result.message);
if
(result.code
!=
1)
{
this.getImgCode();
this.setData({
captchaSended:
false,
});
}
else
{
var
counter
=
setInterval(()
=>
{
that.timer--;
this.setData({
timer:
that.timer,
captchaText:
`${that.timer}秒`,
isReadOnly:
true
});
if
(that.timer
===
0)
{
clearInterval(counter);
that.captchaSended
=
false;
that.captchaText
=
'獲取驗(yàn)證碼';
this.setData({
timer:
60,
captchaText:
'獲取驗(yàn)證碼',
captchaSended:
false
})
}
},
1000);
}
});
}
},
//
獲取圖形碼
getImgCode()
{
var
capKey
=
"zdx-weixin"
+
Math.random();
this.setData({
imgCodeSrc:
"/invite/WeChat/verify?capKey="
+
capKey,
capKey:
capKey
});
},
//用戶使用協(xié)議
xieyi()
{
wx.navigateTo({
url:
'../userXieyi/userXieyi'
})
},
//
注冊(cè)
regist()
{
var
that
=
this.data;
if(!that.checkAgree||!that.phoneAll){
return
}
//
sessionCheck為1,目的是防止微信code碼先于session過期
var
code
=
wx.getStorageSync('wxCode');
var
sessionCheck
=
wx.getStorageSync('sessionCheck');
wx.setStorageSync('mobile',that.mobile);
if
(!that.mobile)
{
this.showToast('請(qǐng)輸入手機(jī)號(hào)');
}
else
if
(that.mobile.length
!=
11
||
isNaN(that.mobile))
{
this.showToast('請(qǐng)輸入正確手機(jī)號(hào)');
}
else
if
(that.code.length
!=
6)
{
this.showToast('請(qǐng)輸入正確驗(yàn)證碼');
}
else
{
wx.showLoading({
title:
'加載中...',
});
app.api.loginByCaptcha({
mobile:
that.mobile,
smsCode:
that.code,
code:
code,
sessionCheck:sessionCheck,
}).then((res)
=>
{
wx.hideLoading();
if
(res.code
==
2||res.code==1)
{
//注冊(cè)成功
wx.setStorageSync('token',
res.businessObj.token);
wx.setStorageSync('userId',res.businessO
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 供方采購合同范本
- 企業(yè)項(xiàng)目合資合同范本
- 浙江長興縣龍山中學(xué)人教版七年級(jí)下冊(cè)歷史與社會(huì)第八單元第三課 中華文明探源教學(xué)設(shè)計(jì)
- 2024年韶關(guān)市曲江區(qū)住房和城鄉(xiāng)建設(shè)管理局招聘筆試真題
- 公司英文合同范本
- 農(nóng)田路養(yǎng)護(hù)合同范本
- 前臺(tái)收銀合同范本
- 包材銷售合同范本
- 2024年金昌市金川區(qū)圖書館招聘筆試真題
- 農(nóng)村自建住宅買賣合同范本
- 瀝青路面施工質(zhì)量控制要78課件講解
- 16.2《登泰山記》課件 2024-2025學(xué)年統(tǒng)編版高中語文必修上冊(cè)-9
- 【課件】如何保障我國未來的能源安全
- 2024年深圳科技企業(yè)員工聘用合同3篇
- 警察著裝管理規(guī)定
- 結(jié)腸術(shù)后恢復(fù)護(hù)理
- 綜藝節(jié)目贊助合同(2024年版)
- 道路運(yùn)輸企業(yè)主要負(fù)責(zé)人和安全生產(chǎn)管理人員安全考核習(xí)題庫(附參考答案)
- 2024東莞市勞動(dòng)局制定的勞動(dòng)合同范本
- 土石方運(yùn)輸中介三方合同協(xié)議書
- 2024年四川省公務(wù)員考試《行測(cè)》真題及答案解析
評(píng)論
0/150
提交評(píng)論