位置: 编程技术 - 正文

gameboy网页闯关游戏(riddle webgame)--仿微信聊天的前端页面设计和难点(网页过关类游戏)

编辑:rootadmin

推荐整理分享gameboy网页闯关游戏(riddle webgame)--仿微信聊天的前端页面设计和难点(网页过关类游戏),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:游戏闯关页面,闯关游戏在线玩,网页闯关游戏,gameboy闯关游戏,网游闯关游戏,gameboy闯关游戏,gameboy闯关游戏,网页闯关游戏,内容如对您有帮助,希望把文章链接给更多的朋友!

前言:

  之前编写了一个网页闯关游戏(类似Riddle Game), 除了希望大家能够体验一下我的游戏外. 也愿意分享编写这个网页游戏过程中, 学到的一些知识.

  本文讲描述, 如何在网页端实现一个仿微信的聊天窗口界面, 以及其中涉及到的一些技术点. 作者前端是初学者, 请大拿们轻拍.

效果展示:

  这种聊天对话的布局模式, 比PC端QQ的那种聊天方式更贴近移动端, 我个人感觉.

需求设定:

  让我们先过一遍, 实现该聊天窗口需要支持的一些功能点.

  &#; 聊天消息结构和布局

  聊天消息包括: 人物(头像)和消息内容. 朋友消息位居左侧, 自己消息则位于右侧, 方便区分.

  &#; 文本区域的自适应

  消息内容可以自适应大小, 总是以最合理的区域大小包裹.

 &#; 滚动支持

  因聊天记录太多, 大小超过聊天窗口的预设尺寸.

  &#; 底部自动对齐

  有新消息后, 窗口内容自动对齐到可视窗口的底部.

  &#; Enter键捕获

gameboy网页闯关游戏(riddle webgame)--仿微信聊天的前端页面设计和难点(网页过关类游戏)

  消息的输入支持, 以及捕获响应Enter键.

  这几个功能点中, 感觉最难的是文本区域自适应处理, 走了不少弯路, ^_^.

实现方案:

  &#; 聊天消息结构和布局

  基本的html代码结构可以如下所示:

  注: 头像为一个img标签, 文本消息内容则为一个div, 包裹两者的是另一个大的div, 代表完整的一个消息.

  对于布局的左偏移和右偏移, 则借助float:left|right, 来进行控制, 这个还是基础的.

  &#; 文本区域的自适应

  为了让聊天的文本内容显得美观, 最好方式就是自适应的文本区域(有个max-width, 区域最小化).

  最初的时候, 我尝试了textarea标签, 因为其属性有row和col, 对应字符个数单位, 可以用于设定行数和列数.

  可惜的是, 我被现实打败了, 因为textarea对中文字符和英文字符的计算标准不同, 中文字符按2个算, 英文字符按1个算. 因为用户输入的不确定, 导致很难用文本串的长度来设定textarea的行列值.

  于是回到起点, 只能走计算文本像素点px长度的方式来设定大小(等价于限定max-width).

  计算文本的长度, 参考于"JQuery 计算文本的总宽度 Width".

  注: 巧妙的通过添加/删除<pre>标签, 返回<pre>的真实长度, 既文本长度.

  对于小于预设的max-width, 则文本区域div缺省即可. 对于大于预设的max-width值, 则文本区域div设定为width=max-width.

  当然这边还有一个需要的注意的地方, 就是自动换行.

后记:

  原本以为实现一个聊天窗口的示例很容易, 却在真正的实践过程中磕磕碰碰, 步履蹒跚. 前端这一块, 真心水很深. 事后回忆起来,觉得收获很大, 当然对于文本的自适应, 采用了一个较复杂的办法. 后来想想是不是加个max-width属性就能轻松搞定了&#;

好了,关于本文给大家介绍的gameboy网页闯关游戏(riddle webgame)--仿微信聊天的前端页面设计和难点就给大家介绍这么多,希望对大家走gameboy网页闯关游戏有所帮助!

浏览器检测JS代码(兼容目前各大主流浏览器) 本文实例介绍了JS代码实现浏览器检测,分享给大家供大家参考,具体内容如下varBrowserMatch={init:function(){this.browser=this.getBrowser().browser||"AnUnknownBrowser";this

JS中Eval解析JSON字符串的一个小问题 之前写过一篇关于JSON的介绍文章,里面谈到了JSON的解析。我们都知道,高级浏览器可以用JSON.parse()API将一个JSON字符串解析成JSON数据,稍微欠妥点的做

javascript实现计时器的简单方法 计时器,在生活当中也是用得频繁的功能,比如锻炼身体,跑步比赛等等相关的活动.我们用Javascript来完成一个计时器.计时器,主要就是对时间的一个逻辑处

标签: 网页过关类游戏

本文链接地址:https://www.jiuchutong.com/biancheng/380395.html 转载请保留说明!

上一篇:js面向对象的写法(js面向对象的原理)

下一篇:浏览器检测JS代码(兼容目前各大主流浏览器)(浏览器检测js代码)

  • 预收三年租金 房产税怎么算
  • 超率累进税率有哪些税种呢怎么算
  • 利润分配未分配利润和未分配利润的区别
  • 固定资产直接计入成本的规定
  • 承兑汇票私人贴现要多久
  • 电商平台返佣金税务怎么走
  • 普通发票不能抵扣进项税额怎么做账
  • 会计凭证整理的要求有哪些
  • 小规模跨年发票可以入账吗
  • 固定资产采购计入什么科目
  • 收到外国客户的祝福怎么回复
  • 缴纳土地出让金购买的土地是无形资产吗
  • 营改增之后的税率
  • 开票未收到款会计分录
  • 增值税科目设置的凭证处理方面的特殊要求
  • 国税网上三方协议流程 个人所得税
  • 领购纳税人状态注销或转非日期什么意思
  • 水利建设专项收入怎么计算
  • 如何界定企业所得税的不征税收入与应税收入
  • 公司的净资产怎么看
  • 污水处理费计入哪里
  • 研发产品样品对我出售账务处理
  • 预付专利转让费计入什么科目?
  • 工资本月计提下月发放,个税如何计算做账
  • 物业公司哪些收费项目
  • 查账征收改为核定征收需要什么资料
  • 适用加计抵减政策的行业
  • win7为什么显示多重网络
  • 单位办事人员
  • vue3全局属性
  • 海恩斯科普简介
  • 公司的土地
  • 主营业务收入月末需要结转吗
  • lvs命令
  • ftp port命令
  • python random random
  • 税款已缴纳后发票怎么查
  • 什么叫预缴款
  • 税控盘抵税的会计分录
  • 软件开发公司如何保护源码
  • css边框实现效果图及代码
  • 企业待摊费用怎么计算
  • 口罩属于什么经济分类
  • mysql切片
  • 劳务公司给包工头转账交税吗
  • 红字发票冲销的申请表是税务局开吗
  • 纳税申报怎么做
  • 应收账款属于什么会计要素
  • 公司买车可以少多少钱
  • 免税的发票什么样子
  • 汽车以租代购可靠吗
  • 用友t3计提折旧了没有生成凭证
  • 小规模购入固定资产怎么做账
  • 销售发票已开进项发票未收到怎么处理?
  • 年度计提资产减值准备 好还是坏
  • 租金是含税价还是含税金
  • 在哪找从平台消费的人
  • 代理返利
  • 建设工程毛利率如何计算
  • 资金账簿印花税税率
  • win8操作
  • 如何强制退出当前程序mac
  • 注册表及其作用
  • windowsxp停止服务的时间
  • 怎么更改桌面图标字体
  • win8.1无法连接wifi
  • u盘比特率
  • 升级win10后无法修改magicbook开机画面
  • win7安装kb3170455失败
  • unity alembic
  • jQuery实现checkbox即点即改批量删除及中间遇到的坑
  • 细说javascript
  • javascript教程完整版
  • python语言文件
  • 使用筷子就餐会不会传染乙肝病毒
  • javascript object oriented 面向对象编程初步
  • javascript面向对象吗
  • 电子税务局税务数字证书登录
  • 普洱房产管理局官网
  • 韩国工资多少人民币
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设