欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解微信小程序?qū)崿F(xiàn)仿微信聊天界面(各種細節(jié)處理)

 更新時間:2019年02月17日 10:18:33   作者:盛國強  
這篇文章主要介紹了詳解微信小程序?qū)崿F(xiàn)仿微信聊天界面(各種細節(jié)處理),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

本文介紹了微信小程序?qū)崿F(xiàn)仿微信聊天界面,分享給大家,具體如下:

下面先來看看效果

為實現(xiàn)這樣的效果,首先要解決兩個問題:

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

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

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

1.計算每條消息的最大高度,設(shè)置scroll-top=(單條msg最大高度 * msg條數(shù))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)
})

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

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

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

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

而不是:adjust-position='false'。

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

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

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

提示:

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

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

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

各位要不要代碼?

contact.js:

// pages/contact/contact.js
const app = getApp();
var inputVal = '';
var msgList = [];
var windowWidth = wx.getSystemInfoSync().windowWidth;
var windowHeight = wx.getSystemInfoSync().windowHeight;
var keyHeight = 0;

/**
 * 初始化數(shù)據(jù)
 */
function initData(that) {
 inputVal = '';

 msgList = [{
   speaker: 'server',
   contentType: 'text',
   content: '歡迎來到英雄聯(lián)盟,敵軍還有30秒到達戰(zhàn)場,請做好準備!'
  },
  {
   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({

 /**
  * 頁面的初始數(shù)據(jù)
  */
 data: {
  scrollHeight: '100vh',
  inputBottom: 0
 },

 /**
  * 生命周期函數(shù)--監(jiān)聽頁面加載
  */
 onLoad: function(options) {
  initData(this);
  this.setData({
   cusHeadIcon: app.globalData.userInfo.avatarUrl,
  });
 },

 /**
  * 生命周期函數(shù)--監(jiān)聽頁面顯示
  */
 onShow: function() {

 },

 /**
  * 頁面相關(guān)事件處理函數(shù)--監(jiān)聽用戶下拉動作
  */
 onPullDownRefresh: function() {

 },

 /**
  * 頁面上拉觸底事件的處理函數(shù)
  */
 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)
  })

 },

 /**
  * 發(fā)送點擊監(jiān)聽
  */
 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 客服發(fā)出(左) -->
   <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 用戶發(fā)出(右) -->
   <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;
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Typescript學習之接口interface舉例詳解

    Typescript學習之接口interface舉例詳解

    TypeScript是JavaScript的一個超集,主要提供了類型系統(tǒng)和對ES6+的支持,TypeScript的核心原則之一是對值所具有的結(jié)構(gòu)進行類型檢查,這篇文章主要給大家介紹了關(guān)于Typescript學習之接口interface的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • bootstrap滾動監(jiān)控器使用方法解析

    bootstrap滾動監(jiān)控器使用方法解析

    這篇文章主要為大家詳細解析了bootstrap滾動監(jiān)控器使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • JS是否可以跨文件同時控制多個iframe頁面的應用技巧

    JS是否可以跨文件同時控制多個iframe頁面的應用技巧

    這篇文章給大家詳細介紹了JS是否可以跨文件同時控制多個iframe頁面的應用技巧,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2007-12-12
  • 不使用jquery實現(xiàn)js打字效果示例分享

    不使用jquery實現(xiàn)js打字效果示例分享

    js打字效果示例js打字效果示例,data-period設(shè)置從打字返回刪字的時間,data-rotate可加減中英文詞語,不用jquery支持
    2014-01-01
  • js實現(xiàn)交通燈效果

    js實現(xiàn)交通燈效果

    本文主要介紹了js實現(xiàn)交通燈效果的示例代碼。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • 解決layui使用layui-icon出現(xiàn)默認圖標的問題

    解決layui使用layui-icon出現(xiàn)默認圖標的問題

    今天小編就為大家分享一篇解決layui使用layui-icon出現(xiàn)默認圖標的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 如何從JavaScript數(shù)組中刪除空對象

    如何從JavaScript數(shù)組中刪除空對象

    JS中數(shù)組是我們較為常用的一種數(shù)據(jù)結(jié)構(gòu),下面這篇文章主要給大家介紹了關(guān)于如何從JavaScript數(shù)組中刪除空對象的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-05-05
  • 利用JavaScript實現(xiàn)簡單的網(wǎng)頁時鐘

    利用JavaScript實現(xiàn)簡單的網(wǎng)頁時鐘

    這篇文章主要介紹了利用JavaScript實現(xiàn)簡單的網(wǎng)頁時鐘,主要使用了js的日期對象,實現(xiàn)的時候先創(chuàng)建一個日期對象,并進行網(wǎng)頁布局,對時間獲取之后將時間填入對應的標簽內(nèi)。然后使用多線程實現(xiàn)時鐘的變動,需要的朋友可以參考一下
    2022-02-02
  • javascript添加前置0(補零)的幾種方法

    javascript添加前置0(補零)的幾種方法

    很多時候為了顯示格式,需要在某一字符串不滿位的情況下進行前補0操作。下面這篇文章就給大家主要介紹了javascript添加前置0(補零)的幾種方法,文中給出了詳細的示例代碼,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-01-01
  • document.cookie 使用小結(jié)

    document.cookie 使用小結(jié)

    這篇文章主要介紹了document.cookie 使用,主要包括cookie設(shè)置,修改cookie值及獲取cookie值的相關(guān)知識,本文給大家介紹的非常詳細,需要的朋友可以參考下
    2022-06-06

最新評論