亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 課堂 > 小程序 > 正文

詳解微信小程序實現仿微信聊天界面(各種細節處理)

2020-03-21 16:01:45
字體:
來源:轉載
供稿:網友

本文介紹了微信小程序實現仿微信聊天界面,分享給大家,具體如下:

下面先來看看效果

微信小程序

為實現這樣的效果,首先要解決兩個問題:

1.點擊輸入框彈出軟鍵盤后,將已有的少許聊天內容彈出,導致看不到的問題;

2.鍵盤彈出或收起時,聊天消息沒有自動滾到最底部。

首先解決第二個問題,自動滾動到最底部,這很簡單,這里提供三種方法(推薦第三種):

1.計算每條消息的最大高度,設置scroll-top=(單條msg最大高度 * msg條數)px。

2.用 將展示msg的目標scroll-view包裹,

通過js獲取到該view的實際高度:

var that = this;var query = wx.createSelectorQuery();query.select('.scrollMsg').boundingClientRect(function(rect) {	that.setData({		scrollTop: rect.height+'px';	});}).exec();

3.(推薦)將所有msg都編號如:msg-0,msg-1,msg-2… 直接鎖定最后一條msg,滾動到那里。

  • 在scroll-view中添加:scroll-into-view='{{toView}}',
  • 在wx:for后面添加:wx:for-index="index",
  • 在每個msg布局中添加:id='msg-{{index}}',

最后直接:

this.setData({	toView: 'msg-' + (msgList.length - 1)})

到這里第二個問題解決了,那么我們回過來解決第一個問題:

(點擊輸入框彈出軟鍵盤后,將已有的少許聊天內容彈出,導致看不到的問題)

1.首先我們需要將input的自動向上推給關掉,這里有個坑:

在input組件中添加:adjust-position='{{false}}',

而不是:adjust-position='false'

這么做雖然不再向上推,但卻導致了軟鍵盤彈起時,會遮擋屏幕下部分的消息。

2.如何解決軟鍵盤彈起時,會遮擋屏幕下部分的消息?

當軟鍵盤彈起時,將scroll-view的高度縮短至軟鍵盤遮擋不到的屏幕上方部分,當軟鍵盤收起時,再將scroll-view的高度還原,這樣解決了遮擋問題。

提示:

input中的bindfocus='focus'可獲取軟鍵盤高度并監聽軟鍵盤彈起,bindblur='blur'可監聽軟鍵盤收起,var windowHeight = wx.getSystemInfoSync().windowHeight;可獲得屏幕高度。

scrollHeight(滾動條高度) = windowHeight(屏幕高度) - 軟鍵盤高度;

最后將input組件放在軟鍵盤上面就完成了。

各位要不要代碼?

contact.js:

// pages/contact/contact.jsconst app = getApp();var inputVal = '';var msgList = [];var windowWidth = wx.getSystemInfoSync().windowWidth;var windowHeight = wx.getSystemInfoSync().windowHeight;var keyHeight = 0;/** * 初始化數據 */function initData(that) { inputVal = ''; msgList = [{   speaker: 'server',   contentType: 'text',   content: '歡迎來到英雄聯盟,敵軍還有30秒到達戰場,請做好準備!'  },  {   speaker: 'customer',   contentType: 'text',   content: '我怕是走錯片場了...'  } ] that.setData({  msgList,  inputVal })}/** * 計算msg總高度 */// function calScrollHeight(that, keyHeight) {//  var query = wx.createSelectorQuery();//  query.select('.scrollMsg').boundingClientRect(function(rect) {//  }).exec();// }Page({ /**  * 頁面的初始數據  */ data: {  scrollHeight: '100vh',  inputBottom: 0 }, /**  * 生命周期函數--監聽頁面加載  */ onLoad: function(options) {  initData(this);  this.setData({   cusHeadIcon: app.globalData.userInfo.avatarUrl,  }); }, /**  * 生命周期函數--監聽頁面顯示  */ onShow: function() { }, /**  * 頁面相關事件處理函數--監聽用戶下拉動作  */ onPullDownRefresh: function() { }, /**  * 頁面上拉觸底事件的處理函數  */ onReachBottom: function() { }, /**  * 獲取聚焦  */ focus: function(e) {  keyHeight = e.detail.height;  this.setData({   scrollHeight: (windowHeight - keyHeight) + 'px'  });  this.setData({   toView: 'msg-' + (msgList.length - 1),   inputBottom: keyHeight + 'px'  })  //計算msg高度  // calScrollHeight(this, keyHeight); }, //失去聚焦(軟鍵盤消失) blur: function(e) {  this.setData({   scrollHeight: '100vh',   inputBottom: 0  })  this.setData({   toView: 'msg-' + (msgList.length - 1)  }) }, /**  * 發送點擊監聽  */ sendClick: function(e) {  msgList.push({   speaker: 'customer',   contentType: 'text',   content: e.detail.value  })  inputVal = '';  this.setData({   msgList,   inputVal  }); }, /**  * 退回上一頁  */ toBackClick: function() {  wx.navigateBack({}) }})

contact.wxml:

<!--pages/contact/contact.wxml--><view> <scroll-view scroll-y scroll-into-view='{{toView}}' style='height: {{scrollHeight}};'>  <!-- <view class='scrollMsg'> -->  <block wx:key wx:for='{{msgList}}' wx:for-index="index">   <!-- 單個消息1 客服發出(左) -->   <view wx:if='{{item.speaker=="server"}}' id='msg-{{index}}' style='display: flex; padding: 2vw 11vw 2vw 2vw;'>    <view style='width: 11vw; height: 11vw;'>     <image style='width: 11vw; height: 11vw; border-radius: 10rpx;' src='../../images/contact_member.png'></image>    </view>    <view style='width: 4vw; height: 11vw; margin-left: 0.5vw; display: flex; align-items: center; z-index: 9;'>     <image style='width: 4vw;' src='../../images/left_msg.png' mode='widthFix'></image>    </view>    <view class='leftMsg'>{{item.content}}</view>   </view>   <!-- 單個消息2 用戶發出(右) -->   <view wx:else id='msg-{{index}}' style='display: flex; justify-content: flex-end; padding: 2vw 2vw 2vw 11vw;'>    <view class='rightMsg'>{{item.content}}</view>    <view style='width: 4vw; height: 11vw; margin-right: 0.5vw; display: flex; align-items: center; z-index: 9;'>     <image style='width: 4vw;' src='../../images/right_msg.png' mode='widthFix'></image>    </view>    <view style='width: 11vw; height: 11vw;'>     <image style='width: 11vw; height: 11vw; border-radius: 10rpx;' src='{{cusHeadIcon}}'></image>    </view>   </view>  </block>  <!-- </view> -->  <!-- 占位 -->  <view style='width: 100%; height: 18vw;'></view> </scroll-view> <view class='inputRoom' style='bottom: {{inputBottom}}'>  <image style='width: 7vw; margin-left: 3.2vw;' src='../../images/pic_icon.png' mode='widthFix'></image>  <input bindconfirm='sendClick' adjust-position='{{false}}' value='{{inputVal}}' confirm-type='send' bindfocus='focus' bindblur='blur'></input> </view></view>

contact.wxss:

/* pages/contact/contact.wxss */page { background-color: #f1f1f1;}.inputRoom { width: 100vw; height: 16vw; border-top: 1px solid #cdcdcd; background-color: #f1f1f1; position: fixed; bottom: 0; display: flex; align-items: center; z-index: 20;}input { width: 76vw; height: 9.33vw; background-color: #fff; border-radius: 40rpx; margin-left: 2vw; padding: 0 3vw; font-size: 28rpx; color: #444;}.leftMsg { font-size: 35rpx; color: #444; line-height: 7vw; padding: 2vw 2.5vw; background-color: #fff; margin-left: -1.6vw; border-radius: 10rpx; z-index: 10;}.rightMsg { font-size: 35rpx; color: #444; line-height: 7vw; padding: 2vw 2.5vw; background-color: #96EB6A; margin-right: -1.6vw; border-radius: 10rpx; z-index: 10;}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品入口免费视频一| 精品久久久久久久久中文字幕| 久久99久国产精品黄毛片入口| 日韩一区二区三区xxxx| 久久噜噜噜精品国产亚洲综合| 精品国产自在精品国产浪潮| 欧美夫妻性生活视频| 色悠久久久久综合先锋影音下载| 亚洲日韩欧美视频| 欧美裸体xxxx极品少妇| 欧美老女人在线视频| 色香阁99久久精品久久久| 亚洲综合日韩在线| 亚洲国产高潮在线观看| 精品丝袜一区二区三区| 91极品视频在线| 欧美巨乳在线观看| 亚洲欧美日韩国产中文专区| 日韩有码在线电影| 国产aaa精品| 日日噜噜噜夜夜爽亚洲精品| 国产精品欧美日韩| 青青在线视频一区二区三区| 国产精品你懂得| 久久精品精品电影网| 亚洲精品一区二区三区不| 亚洲aⅴ日韩av电影在线观看| 亚洲开心激情网| 疯狂欧美牲乱大交777| 一区二区三区高清国产| 欧美性猛交xxxx黑人猛交| 亚洲精品乱码久久久久久金桔影视| 69av成年福利视频| 国产视频在线一区二区| 国产主播在线一区| 成人黄色大片在线免费观看| 亚洲国产精品中文| 国产精品视频999| 欧美一级电影免费在线观看| 久久久久久一区二区三区| 国产精品久久色| 久久国产精品免费视频| 久久夜色精品国产欧美乱| 97在线视频精品| 热99在线视频| 亚洲第一页中文字幕| 国产精品免费网站| 2021国产精品视频| 国产精品久久久久久久美男| 国产精品吊钟奶在线| 国产视频精品va久久久久久| 性欧美暴力猛交69hd| 色999日韩欧美国产| 98精品在线视频| 午夜免费日韩视频| 在线电影av不卡网址| 亚洲男人的天堂在线播放| 欧美亚洲午夜视频在线观看| 中文字幕国产亚洲2019| 欧美日本中文字幕| 久久精品视频播放| 久久人人爽人人爽人人片亚洲| 日本三级久久久| 亚洲午夜国产成人av电影男同| 成人av色在线观看| 国产精品自产拍在线观看中文| 亚洲毛片在线免费观看| 欧美噜噜久久久xxx| 成人欧美一区二区三区在线湿哒哒| 51久久精品夜色国产麻豆| 成人精品视频99在线观看免费| 久久精品久久精品亚洲人| 亚洲综合在线小说| 久久躁日日躁aaaaxxxx| 国产精品电影在线观看| 91产国在线观看动作片喷水| 91欧美日韩一区| 精品欧美一区二区三区| 亚洲综合在线小说| 亚洲精品国产免费| 国产成人高清激情视频在线观看| 国产精品久久久久影院日本| 欧洲精品在线视频| 九九热精品视频| 精品欧美一区二区三区| 国产精品久久二区| 亚洲成av人乱码色午夜| 国产91精品最新在线播放| 亚洲国产精品久久久| 亚洲视频第一页| 久久久亚洲福利精品午夜| 91地址最新发布| 欧美重口另类videos人妖| 97成人在线视频| 欧美性猛交xxxx乱大交蜜桃| 亚洲免费av网址| 日韩综合视频在线观看| 国产一区二区三区18| 欧美成人精品不卡视频在线观看| 韩曰欧美视频免费观看| 尤物yw午夜国产精品视频明星| 亚洲最大福利网| 日韩电影在线观看中文字幕| www.欧美精品| 亚洲精品欧美一区二区三区| 日韩**中文字幕毛片| 日韩精品高清在线观看| 精品视频久久久久久| 91精品国产自产在线观看永久| 日韩三级影视基地| 欧美在线视频免费观看| 亚洲国产成人精品电影| 成人性生交大片免费观看嘿嘿视频| 亚洲精品一区二区网址| 欧美极品少妇xxxxx| 国内精品久久久久久| 91精品久久久久久久| 成人精品视频99在线观看免费| 欧美重口另类videos人妖| 国产成人97精品免费看片| 亚洲日本成人女熟在线观看| 欧美成人午夜激情| 深夜福利国产精品| 国产精品高潮呻吟久久av黑人| 欧美区在线播放| 狠狠操狠狠色综合网| 欧美成人午夜剧场免费观看| 欧美激情一级二级| 国产自摸综合网| 国产精品视频大全| 亚洲色图美腿丝袜| 国产一区视频在线| 中文字幕在线国产精品| 国产91九色视频| 精品久久在线播放| 精品久久久久久久久国产字幕| 亚洲精品之草原avav久久| 91av福利视频| 国产精品在线看| 日韩中文在线中文网三级| 日韩在线视频免费观看高清中文| 久久影院在线观看| 久久久久久久久久久人体| 日韩精品中文在线观看| 夜夜嗨av一区二区三区四区| 91在线观看欧美日韩| 91免费精品视频| 国产在线一区二区三区| 成人免费视频xnxx.com| 91夜夜揉人人捏人人添红杏| 日产精品久久久一区二区福利| 1769国内精品视频在线播放| 黑人巨大精品欧美一区二区三区| 国产精品久久不能| 国产精品久久久久久久一区探花| 亚洲成人av片在线观看| 欧美成人激情视频免费观看| 欧美丝袜美女中出在线| 亚洲精品电影久久久| 伊人伊成久久人综合网小说| 欧洲永久精品大片ww免费漫画| 中文字幕综合一区| 成人性生交大片免费看小说| 日韩成人在线免费观看|