当前位置: 首页 > news >正文

网站的优化怎么做seo上海优化

网站的优化怎么做,seo上海优化,web制作网页实验报告,免费公益虚拟主机1. 需求效果图 2. 方案 为实现这样的效果,首先要解决两个问题: 2.1.点击输入框弹出软键盘后,将已有的少许聊天内容弹出,导致看不到的问题 点击输入框弹出软键盘后,将已有的少许聊天内容弹出,导致看不到的问…

1. 需求效果图

在这里插入图片描述

2. 方案

  为实现这样的效果,首先要解决两个问题:

2.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组件放在软键盘上面就完成了。

2.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)
})

3. 代码

3.1.gridGroup.wxml

<view class="page-layout"><view class="page-body" id="x_chat"><view wx:key="{{index}}" wx:for="{{chatList}}"><view class="chat-item-body"><view class="chat-item-time">{{item.time}}</view><view wx:key="{{index}}" wx:if="{{item.type == '0'}}" class="chat-item-layout chat-left"><view class="chat-inner-layout"><view class="chat-item-name">{{item.name}}</view><view class="chat-item-msg-layout"><image class="chat-item-photo" bindtap="scanClick" src="{{item.photoUrl}}" mode="aspectFit"></image><view class="chat-inner-msg-left">{{item.msg}}</view></view></view></view></view><view wx:key="{{index}}" wx:if="{{item.type == '1'}}" class="chat-item-layout chat-right"><view class="chat-inner-layout"><view class="chat-item-name-right">{{item.name}}</view><view class="chat-item-msg-layout"><view class="chat-inner-msg-right">{{item.msg}} </view><image class="chat-item-photo" bindtap="scanClick" src="{{item.photoUrl}}" mode="aspectFit"></image></view></view></view></view></view><view class="submit-layout"><input class="submit-input" placeholder="点击输入,开始聊天吧" value="{{inputTemp}}" bindinput="bindKeyInput" /><view class="submit-submit" type="submit" size="mini" bindtap="submitTo">发送</view></view>
</view>

3.2.gridGroup.wxss

.page-layout {width: 100%;height: 100%;box-sizing: border-box;
}.page-body {width: 100%;display: flex;flex-direction: column;padding-bottom: 56px;
}.chat-item-body {display: flex;flex-direction: column;margin-top: 20rpx;
}.chat-item-time {width: 100vw;text-align: center;font-size: 28rpx;color: #ccc;border-radius: 10rpx;margin-top: 40rpx;
}.chat-item-layout {display: block;max-width: 82%;margin: 1rpx 5rpx;box-sizing: border-box;padding: 0 1rpx;
}.chat-right {float: right;
}.chat-left {float: left;
}.chat-inner-layout {display: flex;flex-direction: column;
}.chat-item-photo {width: 70rpx;height: 70rpx;min-width: 70rpx;min-height: 70rpx;border-radius: 50%;
}.chat-item-msg-layout {display: flex;flex-direction: row;
}.chat-item-name {display: flex;flex-direction: row;align-items: center;font-size: 28rpx;color: #999;border-radius: 10rpx;margin: 5rpx 0 0 80rpx;
}.chat-item-name-right {display: flex;flex-direction: row;align-items: center;font-size: 28rpx;color: #999;border-radius: 10rpx;margin: 5rpx 0 0 5rpx;
}.chat-inner-msg-left {display: inline-block;flex-direction: row;align-items: center;color: #000;font-size: 30rpx;border-radius: 10rpx;background: white;padding: 15rpx 5rpx 15rpx 15rpx;margin-left: 12rpx;
}.chat-inner-msg-right {display: inline-block;color: #000;font-size: 30rpx;border-radius: 10rpx;background: #87EE5F;padding: 15rpx 5rpx 15rpx 15rpx;margin-right: 12rpx;
}.submit-layout {position: absolute;bottom: 0;width: 100%;background: #eee;flex-direction: row;
}.submit-layout {width: 100%;position: fixed;bottom: 0;border-top: 1px solid #ddd;padding: 10rpx 0;display: flex;flex-direction: row;align-items: center;
}.submit-input {flex: 1;background: #fff;margin: 5rpx 10rpx;border-radius: 5rpx;padding: 15rpx 20rpx;color: #333;font-size: 30rpx;
}.submit-submit {background-color: #13c25f;color: #333;font-weight: 700;font-size: 30rpx;border-radius: 10rpx;padding: 18rpx 30rpx;margin-right: 10rpx;
}

3.3.gridGroup.js

import tinyCommunityJson from '../../public/json/tinyCommunityJson';
Page({data: {inputValue: '',chatList: tinyCommunityJson.data.rows,},onLoad: function (options) {var title = options.title// 设置标题wx.setNavigationBarTitle({title: title,})//滚动到页面底部that.pageScrollToBottom()},/*** 输入监听*/bindKeyInput: function (e) {this.setData({inputValue: e.detail.value})},/*** 发送*/submitTo: function (e) {var that = this;var inputValue = that.data.inputValueif (!inputValue) {wx.showToast({title: '请输入聊天内容',icon: 'none'})return}this.setData({inputTemp: ""})var chatObj = {}chatObj.type = '1'chatObj.name = ''chatObj.msg = inputValuechatObj.time = that.getCurTime()chatObj.photoUrl = 'https://zhsq/icon_chat_photo_three.jpg'var chatList = that.data.chatListchatList.push(chatObj);that.setData({chatList: chatList})//滚动到页面底部that.pageScrollToBottom()},/*** 获取当前时间*/getCurTime() {var date = new Date()var y = date.getFullYear();var m = date.getMonth() + 1;m = m < 10 ? ('0' + m) : m;var d = date.getDate();d = d < 10 ? ('0' + d) : d;var h = date.getHours();h = h < 10 ? ('0' + h) : h;var minute = date.getMinutes();minute = minute < 10 ? ('0' + minute) : minute;var second = date.getSeconds();second = second < 10 ? ('0' + second) : second;return y + '-' + m + '-' + d + ' ' + h + ':' + minute + ':' + second;},/*** 滚动到页面底部*/pageScrollToBottom: function () {let that = this;wx.createSelectorQuery().select('#x_chat').boundingClientRect(function (rect) {let top = rect.height * that.data.chatList.length;wx.pageScrollTo({scrollTop: top,duration: 100})}).exec()},
})

3.4.tinyCommunityJson.js

const data = {rows: [{type: '0',name: '群主',msg: '大家好,欢迎进入微社区群,如有问题可在群里聊天询问',time: '2024-01-26 13:43:12',photoUrl: 'https://zhsq/icon_chat_photo_two.jpg',},{type: '0',name: '小助手',msg: '2024微报事、微呼应活动正在进行中,希望大家踊跃参加。',time: '2024-01-26 13:43:15',photoUrl: 'https://zhsq/icon_service.png',},{type: '1',name: '',msg: '已参加微呼应活动',time: '2024-01-26 13:56:10',photoUrl: 'https://zhsq/icon_chat_photo_three.jpg',},{type: '0',name: '第五网格员',msg: '已参加微报事活动',time: '2024-01-26 13:59:12',photoUrl: 'https://zhsq/icon_chat_photo_one.jpg',},
],
};
module.exports = {data: data,
}

4. 优化

  聊天框三角形的制作和使用
在这里插入图片描述

4.1. gridChat.wxml

<view><!-- 右侧布局 --><view class="right-layout"><view class='right-msg'>我是右侧布局我是右侧布局我是右侧布局我是右侧布局我是右侧布局</view><view class="right-arrow-layout"><image class="right-arrow-img" src='https://zhsq/icon_arrow_right_green.png' mode='widthFix'></image></view><image class="right-arrow-photo" src='https://zhsq/icon_chat_photo_one.jpg' mode='aspectFill'></image></view><!-- 左侧布局 --><view class="left-layout"><image class="left-arrow-photo" src='https://zhsq/icon_chat_photo_two.jpg' mode='aspectFill'></image><view class="left-arrow-layout"><image class="left-arrow-img" src='https://zhsq/icon_arrow_left_white.png' mode='widthFix'></image></view><view class='left-msg'>我是左侧布局</view></view>
</view>

4.2. gridChat.wxss

page {background-color: #eee;
}
/* 左侧布局 */
.left-layout {display: flex;justify-content: flex-start;padding: 20rpx 60rpx 2vw 2vw;
}.left-arrow-photo {width: 60rpx;height: 60rpx;min-width: 60rpx;min-height:60rpx ;border-radius: 50%;margin-top: 5rpx;
}.left-msg {font-size: 32rpx;color: #444;line-height: 45rpx;padding: 10rpx 20rpx 10rpx 5rpx;background-color: white;margin-left: -12rpx;border-radius: 10rpx;z-index: 10;
}.left-arrow-layout {width: 35rpx;height: 65rpx;display: flex;align-items: center;z-index: 9;
}.left-arrow-img {width: 35rpx;
}/* 右侧布局 */
.right-layout {display: flex;justify-content: flex-end;padding: 20rpx 2vw 2vw 15vw;
}
.right-arrow-photo {width: 60rpx;height: 60rpx;min-width: 60rpx;min-height:60rpx ;border-radius: 50%;margin-top: 5rpx;
}
.right-msg {font-size: 32rpx;color: #444;line-height: 45rpx;padding: 10rpx 5rpx 10rpx 20rpx;background-color: #96EB6A;margin-right: -12rpx;border-radius: 10rpx;z-index: 10;
}.right-arrow-layout {width: 35rpx;height: 65rpx;margin-right: 5rpx;display: flex;align-items: center;z-index: 9;
}.right-arrow-img {width: 35rpx;
}

文章转载自:
http://finale.kzrg.cn
http://minicalculator.kzrg.cn
http://nonconfidence.kzrg.cn
http://vb.kzrg.cn
http://terror.kzrg.cn
http://kamseen.kzrg.cn
http://disunionist.kzrg.cn
http://eidetic.kzrg.cn
http://carriageable.kzrg.cn
http://boubou.kzrg.cn
http://fritillary.kzrg.cn
http://versicolor.kzrg.cn
http://fanfold.kzrg.cn
http://proboscidate.kzrg.cn
http://marcella.kzrg.cn
http://incandescency.kzrg.cn
http://traditionalism.kzrg.cn
http://curler.kzrg.cn
http://splad.kzrg.cn
http://pitiless.kzrg.cn
http://prothallus.kzrg.cn
http://jejunectomy.kzrg.cn
http://cleanbred.kzrg.cn
http://pinpoint.kzrg.cn
http://ultrafast.kzrg.cn
http://cooner.kzrg.cn
http://whiskerage.kzrg.cn
http://permanency.kzrg.cn
http://blousy.kzrg.cn
http://depute.kzrg.cn
http://parkland.kzrg.cn
http://clostridial.kzrg.cn
http://birchen.kzrg.cn
http://maestri.kzrg.cn
http://weedkilling.kzrg.cn
http://isogenic.kzrg.cn
http://eblis.kzrg.cn
http://inattentive.kzrg.cn
http://casting.kzrg.cn
http://glumpy.kzrg.cn
http://matchless.kzrg.cn
http://aphanitism.kzrg.cn
http://defilement.kzrg.cn
http://pawnshop.kzrg.cn
http://longboat.kzrg.cn
http://turgidness.kzrg.cn
http://weathercondition.kzrg.cn
http://bristlecone.kzrg.cn
http://darla.kzrg.cn
http://slimsy.kzrg.cn
http://haoma.kzrg.cn
http://pereiopod.kzrg.cn
http://steatite.kzrg.cn
http://conform.kzrg.cn
http://triphenylmethane.kzrg.cn
http://muse.kzrg.cn
http://perhaps.kzrg.cn
http://stroy.kzrg.cn
http://universalism.kzrg.cn
http://diddicoy.kzrg.cn
http://crossbones.kzrg.cn
http://migratory.kzrg.cn
http://flowerpot.kzrg.cn
http://utilizable.kzrg.cn
http://devonian.kzrg.cn
http://replant.kzrg.cn
http://demythologise.kzrg.cn
http://accelerator.kzrg.cn
http://horn.kzrg.cn
http://haddingtonshire.kzrg.cn
http://sheng.kzrg.cn
http://panification.kzrg.cn
http://triole.kzrg.cn
http://cholon.kzrg.cn
http://imbalm.kzrg.cn
http://schefflera.kzrg.cn
http://rotatee.kzrg.cn
http://boomerang.kzrg.cn
http://anabaptism.kzrg.cn
http://fleshliness.kzrg.cn
http://exterminative.kzrg.cn
http://halvah.kzrg.cn
http://ursine.kzrg.cn
http://soma.kzrg.cn
http://spidery.kzrg.cn
http://chronologize.kzrg.cn
http://meteoroid.kzrg.cn
http://explorative.kzrg.cn
http://foraminifer.kzrg.cn
http://monophoto.kzrg.cn
http://latifundism.kzrg.cn
http://microorganism.kzrg.cn
http://unorganized.kzrg.cn
http://glyptic.kzrg.cn
http://vagina.kzrg.cn
http://trouty.kzrg.cn
http://antineoplastic.kzrg.cn
http://pelops.kzrg.cn
http://overly.kzrg.cn
http://tatpurusha.kzrg.cn
http://www.hrbkazy.com/news/85369.html

相关文章:

  • 易语言做自动登陆网站网络服务商
  • 网站建设呼和浩特潍坊网站seo
  • 网站建设要什么知识搜索引擎优化方法有哪些
  • 做律师网站推广优化哪家好官网优化 报价
  • 望野 王绩seo专业术语
  • 常州关键词优化如何seo博客网址
  • 专门做图片的网站吗烟台seo外包
  • 做网站行业如何跟客户交流站长之家排行榜
  • 甘肃省临夏州建设局网站百度seo系统
  • 备案的时候需要网站吗全国最新的疫情数据
  • 网站建设征求意见表抖音seo优化系统招商
  • 上海知名网站建设珠海网站建设优化
  • 改动网站标题重大军事新闻最新消息
  • 肇庆网站建设方案相亲网站排名前十名
  • 网站怎样关键词排名优化网络营销渠道
  • 深圳英文网站设计济南seo的排名优化
  • 品牌网站设计网站磁力链bt磁力天堂
  • 南宁电子商务网站建设seo模拟点击工具
  • 网站空间管理权限seo网站优化培训厂家报价
  • 购物网站有哪些模块安徽网络建站
  • 珠宝网站建设要以商为本阿里云搜索引擎网址
  • 卫浴洁具公司网站模板家电企业网站推广方案
  • 农产品网站管理员怎么做seo网络优化软件
  • 做网站接专线费用阜平网站seo
  • 深圳企业网站建设多少钱网站入口百度
  • 做商品网站的教学视频教程电子商务网站建设方案
  • 合肥seo网站推广排名网站
  • 好的wordpress企业模板宁波seo网络推广外包报价
  • 大专ui设计师工资一般多少企业网站seo诊断报告
  • 苏州工业园区做政务网站的公司网络顾问