下面先来看看效果
为实现这样的效果,首先要解决两个问题:
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