微信小程序清空輸入框信息與實現(xiàn)屏幕往上滾動的示例代碼
微信小程序,是屬于小程序的一種,英文名為Wechat Mini Program,是一種不需要下載安裝即可使用的應(yīng)用,它實現(xiàn)了應(yīng)用“觸手可及”的夢想,用戶掃一掃或搜一下即可打開應(yīng)用。微信小程序也是基于H5,JS的開發(fā)。
一. 清空輸入框信息(重置輸入框信息恢復(fù)默認(rèn)值)
這是我在微信小程序?qū)嵱?xùn)開發(fā)的過程中出現(xiàn)的問題,多次思考后終于解決了輸入框內(nèi)已發(fā)送的消息無法被清空這個問題。從另一個角度說可以把清空輸入框信息理解為重置輸入框信息恢復(fù)初始默認(rèn)值。以下是我的解決方案,希望對你們有所幫助。
首先,當(dāng)用戶從輸入框輸入信息后,就會點擊發(fā)送按鈕進行發(fā)送信息,然后表單對輸入框內(nèi)發(fā)送的消息進行重置恢復(fù)初始默認(rèn)值,方便用戶下一條消息的編輯和發(fā)送。
具體思路如下:
直接上代碼如下:
WXML代碼:
<form> <view class="form"> <!--綁定數(shù)據(jù)--> <input class="input" auto-focus placeholder="請輸入內(nèi)容" bindinput="bindInputData" /> <!--發(fā)送信息并初始化值--> <button class="button" type="primary" form-type="reset" bindtap="sendMsg">發(fā)送</button> </view> </form>
form-type=“reset”,reset屬性的作用是重置,可把表單中的元素重置為它們的默認(rèn)值。
type=“primary”,type屬性的作用是用于控制按鈕的顏色樣式。在微信小程序中,primary屬性默認(rèn)為綠色。
注:form-type="reset"只能應(yīng)用到form標(biāo)簽當(dāng)中,view標(biāo)簽中無效,如果去掉form標(biāo)簽,reset將失去作用。
JS代碼:
//用戶信息 userInfo:{}, inputvalue:'' }, //綁定數(shù)據(jù) bindInputData:function(e){ this.setData({ inputvalue:e.detail.value }); }, //發(fā)送數(shù)據(jù) sendMsg:function(){ if(this.data.inputvalue == ''){ wx.showToast({ title: '消息不能為空~~~', duration: 2000 }) return ; } },
關(guān)于showToast的詳細(xì)內(nèi)容請見wx.showToast(Object object),它的作用是顯示消息提示框。
WXSS代碼:
.form{/*輸入框整體*/ width: 100vw; height: 16vw; border-top: 1px solid #aaa; background-color: #f1f1f1; position: fixed;/*固定定位*/ bottom: 0;/*底端距離為0*/ display: flex; align-items: center; z-index: 20; } .input{/*輸入框*/ width: 285px; height: 36px; background-color: #fff; border-radius: 20px; margin-left: 1vw; padding: 0 10px;/*上下內(nèi)邊距*/ font-size: 28rpx; color: #444; } .button{/*發(fā)送按鈕*/ width: 70px !important;/*按鈕,提升權(quán)重*/ height: 40px; padding: 8px 0; margin-right: 4px; }
實現(xiàn)效果:
二. 實現(xiàn)屏幕自動往上滾動
我在做項目的過程中發(fā)現(xiàn)用戶發(fā)送的消息會被信息輸入框遮擋,而且還需要手動滑動顯示屏幕才能看到用戶所發(fā)的消息。所以想到以下方法解決這個問題。
實現(xiàn)顯示屏幕隨著消息的發(fā)送自動往上滾動,并且使輸入框不會遮擋住所有用戶發(fā)送的消息。
直接上代碼如下:
JS代碼:
// 將屏幕往上滾動,將屏幕底端的顯示內(nèi)容顯示出來 wx.pageScrollTo({ scrollTop: 1000000000, duration: 300 })
關(guān)于pageScrollTo的詳細(xì)內(nèi)容請見wx.pageScrollTo(Object object),它的作用將頁面滾動到目標(biāo)位置,支持選擇器和滾動距離兩種方式定位。
如何解決信息輸入框遮擋了顯示屏幕上的其他用戶對話信息內(nèi)容?
具體思路如下:
在之前的內(nèi)容里,信息輸入框中js代碼用position: fixed將信息輸入框進行固定定位,bottom: 0將輸入框與底端的距離設(shè)置為0。所以我們可以在顯示屏幕底端又加入一個板塊,然后將這個板塊隱藏在信息輸入框下(信息輸入框?qū)鍓K覆蓋,不會影響美觀),在js代碼里添加板塊的高度,寫入與信息輸入框一樣的高度,將顯示屏幕頂?shù)叫畔⑤斎肟虻纳戏?,就不會出現(xiàn)信息輸入框會遮擋顯示屏幕內(nèi)容這個問題。
直接上代碼如下:
WXML代碼:
<view class="block"> <text>隱藏塊</text> </view>
WXSS代碼:
.block{/*隱藏塊*/ width: 100vw; height: 16vw; margin-top: 56vw; border-top: 1px solid #aaa; background-color: #f1f1f1; }
——>以上內(nèi)容分別是關(guān)于如何解決用戶點擊發(fā)送消息后如何將信息輸入框內(nèi)的數(shù)據(jù)初始化,恢復(fù)默認(rèn)值和如何將顯示屏幕隨著用戶消息的發(fā)送自動往上滾動,輸入框不會遮擋顯示屏幕上的其他用戶對話信息內(nèi)容這兩個問題。在第一個問題里用form里的reset屬性解決比較方便,也可以嘗試在js里寫個function函數(shù)將信息輸入框里的數(shù)據(jù)進行初始化。第二個問題里用pageScrollTo方法實現(xiàn)屏幕自動向上滾動和用板塊的辦法將顯示屏幕頂?shù)叫畔⑤斎肟虻纳戏健?/p>
總結(jié)
到此這篇關(guān)于微信小程序清空輸入框信息與實現(xiàn)屏幕往上滾動的示例代碼的文章就介紹到這了,更多相關(guān)微信小程序清空輸入框內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在服務(wù)端(Page.Write)調(diào)用自定義的JS方法詳解
自從[javascript]自定義MessageBox一文發(fā)布以后,很多網(wǎng)友都來信詢問,如何在服務(wù)端調(diào)用ShowInfo方法,周末休息想了個折中的辦法來實現(xiàn)2013-08-08js實現(xiàn)網(wǎng)頁標(biāo)題欄閃爍提示效果實例分析
這篇文章主要介紹了js實現(xiàn)網(wǎng)頁標(biāo)題欄閃爍提示效果的方法,以實例形式分析了網(wǎng)上比較常見的實現(xiàn)方法,并對于原理進行分析并加以改進,最后給出了一個具體的應(yīng)用實例供大家參考,需要的朋友可以參考下2014-11-11JavaScript中的console.log()函數(shù)詳細(xì)介紹
這篇文章主要介紹了JavaScript中的console.log()函數(shù)詳細(xì)介紹,本文講解了什么是console.log()、兼容沒有調(diào)試控制臺的瀏覽器、使用參數(shù)、使用其它日志級別等內(nèi)容,需要的朋友可以參考下2014-12-12