这几天使用H5开发了一个仿微信聊天前端界面,尤其微信底部编辑器那块处理的很好,使用HTML5来开发,虽说功能效果并没有微信那么全,但是也相当不错了,可以发送消息、表情,发送的消息自动回滚定位到底部,另外可以对消息、图片、视频有不同的右键处理提示,还有打赏、占屏等操作。

html代码片段:

  1. <!--BEGIN 打赏-->
  2. <div class="js_dialog" id="J_Dialog_dashang" style="display: none;">
  3. <!--<div class="weui-mask"></div>-->
  4. <div class="weui-dialog">
  5. <i class="weui-xclose"></i>
  6. <div class="weui-dialog__bd">
  7. <!-- //打赏模板区-->
  8. <div class="ws__popup-template">
  9. <h2 class="hdTit">为喜欢的节目打赏</h2>
  10. <div class="item flexbox">
  11. <input class="ipt-txt align-l flex1" type="text" name="dschooseProgram" placeholder="选择打赏节目" readonly />
  12. </div>
  13. <div class="item item-area">
  14. <textarea class="describe" name="content" placeholder="输入打赏语,30字以内(选填)"></textarea>
  15. </div>
  16. <div class="item item-gift" id="J__chooseGift">
  17. <div class="gift flexbox selected" data-gift="001">
  18. <label class="txt"><span>豪车</span><em class="time">霸屏50秒</em></label>
  19. <span class="amount"><em>12</em> <i class="chkbox"></i></span>
  20. </div>
  21. <div class="gift flexbox" data-gift="002">
  22. <label class="txt"><span>动人玫瑰</span><em class="time">霸屏20秒</em></label>
  23. <span class="amount"><em>8</em> <i class="chkbox"></i></span>
  24. </div>
  25. </div>
  26. </div>
  27. </div>
  28. <div class="weui-dialog__ft">
  29. <a href="javascript:;" class="weui-dialog__btn weui-dialog__btn_primary" style="background: #ff4400; border-radius: 4px; color: #fff;">支付 <span><em class="moneyNum">12</em></span> 打赏</a>
  30. </div>
  31. </div>
  32. </div>
  33. <!--END 打赏-->

Javascript代码片段:

  1. /* ——聊天编辑器区域 */
  2. var $editor = $(".J__editorText"), editor = $editor[0];
  3. var $face = $(".emotion-area dd img");
  4. $face.on("click", function(e){
  5. if($(this).hasClass("face")){ //图像
  6. var img = $(this)[0].cloneNode(true);
  7.  
  8. editor.focus();
  9. setTimeout(function(){
  10. var range, node;
  11. if(document.selection && document.selection.createRange){
  12. document.selection.createRange().pasteHTML(img);
  13. }else if(window.getSelection && window.getSelection().getRangeAt){
  14. range = window.getSelection().getRangeAt(0);
  15. range.insertNode(img);
  16. range.collapse(false);
  17.  
  18. var sel = window.getSelection();
  19. sel.removeAllRanges();
  20. sel.addRange(range);
  21. }
  22. }, 16);
  23. }else if($(this).hasClass("del")){ //删除
  24. editor.focus();
  25.  
  26. range = window.getSelection().getRangeAt(0);
  27. range.collapse(false);
  28.  
  29. var sel = window.getSelection();
  30. sel.removeAllRanges();
  31. sel.addRange(range);
  32. document.execCommand("delete");
  33. }
  34. });
  35.  
  36. //...格式化编辑器包含标签
  37. editor.addEventListener("focus", function(evt) {
  38. surrounds()
  39. }, true);
  40. editor.addEventListener("input", function(evt) {
  41. surrounds();
  42. }, false);
  43. function surrounds() {
  44. setTimeout(function () { //chrome
  45. var sel = window.getSelection();
  46. var anchorNode = sel.anchorNode;
  47. if (!anchorNode) return;
  48. if (sel.anchorNode === editor ||
  49. (sel.anchorNode.nodeType === 3 && sel.anchorNode.parentNode === editor)) {
  50.  
  51. var range = sel.getRangeAt(0);
  52. var p = document.createElement("p");
  53. range.surroundContents(p);
  54. range.selectNodeContents(p);
  55. range.insertNode(document.createElement("br")); //chrome
  56. sel.collapse(p, 0);
  57.  
  58. (function clearBr() {
  59. var elems = [].slice.call(editor.children);
  60. for (var i = 0, len = elems.length; i < len; i++) {
  61. var el = elems[i];
  62. if (el.tagName.toLowerCase() == "br") {
  63. editor.removeChild(el);
  64. }
  65. }
  66. elems.length = 0;
  67. })();
  68. }
  69. }, 0);
  70. }
  71.  
  72. //...滚动到聊天内容底部
  73. function scrollToBottom(){
  74. $('.ws__chatMsg-panel').animate({scrollTop: $("#J__chatMsgList").height()}, 300);
  75. }

运行效果:

HTML5仿微信聊天界面、微信朋友圈实例的更多相关文章

  1. HTML5仿手机微信聊天界面

    HTML5仿手机微信聊天界面 这篇文章主要为大家详细介绍了HTML5仿手机微信聊天界面的关键代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下     给大家带来的是HTML5仿手机微信聊天界面, ...

  2. android 仿微信聊天界面,以及语音录制功能

    extends:http://104zz.iteye.com/blog/1709840 本例为模仿微信聊天界面UI设计,文字发送以及语言录制UI. 1先看效果图:     第一:chat.xml设计 ...

  3. Android微信逆向--实现发朋友圈动态

    0x0 前言 最近一直在研究Windows逆向的东西,想着快要把Android给遗忘了.所以就想利用工作之余来研究Android相关的技术,来保持对Android热情.调用微信代码来发送朋友圈动态一直 ...

  4. Swift - 自定义单元格实现微信聊天界面

    1,下面是一个放微信聊天界面的消息展示列表,实现的功能有: (1)消息可以是文本消息也可以是图片消息 (2)消息背景为气泡状图片,同时消息气泡可根据内容自适应大小 (3)每条消息旁边有头像,在左边表示 ...

  5. 生成二维码、微信自定义分享到朋友圈、ipa不从应用商店安装

    生成二维码网址:http://www.liantu.com/ 微信自定义分享到朋友圈:http://www.cnblogs.com/memor-y/p/6728179.html ipa不从应用商店安装 ...

  6. Android:日常学习笔记(8)———开发微信聊天界面

    Android:日常学习笔记(8)———开发微信聊天界面 只做Nine-Patch图片 Nine-Patch是一种被特殊处理过的PNG图片,能够指定哪些区域可以被拉升,哪些区域不可以.

  7. ASP调用SDK微信分享好友、朋友圈

    ASP调用SDK微信分享好友.朋友圈需要用到sha1.asp,我先来上主代码,然后再附加sha1.asp,方便大家直接复制过去即可使用. 页面:shara.asp 1 <%@LANGUAGE=& ...

  8. 高仿qq聊天界面

    高仿qq聊天界面,给有需要的人,界面效果如下: 真心觉得做界面非常痛苦,给有需要的朋友. chat.xml <?xml version="1.0" encoding=&quo ...

  9. vue聊天室|h5+vue仿微信聊天界面|vue仿微信

    一.项目简介 基于Vue2.0+Vuex+vue-router+webpack2.0+es6+vuePhotoPreview+wcPop等技术架构开发的仿微信界面聊天室——vueChatRoom,实现 ...

随机推荐

  1. unity零基础开始学习做游戏(二)让你的对象动起来

    -------小基原创,转载请给我一个面子 小基认为电子游戏与电影最重要的区别就是交互,如果电子游戏没有让你输入的交互功能的话,全程都"只可远观,而不可鼓捣"的话,你可能是在看视频 ...

  2. Day4_闭包含数

    闭包函数: 闭包函数是在作用域的前提下 闭包含数:定义在函数内部的函数,包含对外部作用域名字的引用,而不是对全局作用域名字的引用,那么该内部函数就称为闭包含数. eg: x=1 def f1(): x ...

  3. Golang之Context的使用

    转载自:http://www.nljb.net/default/Golang%E4%B9%8BContext%E7%9A%84%E4%BD%BF%E7%94%A8/ 简介 在golang中的创建一个新 ...

  4. nginx 反向代理,支持跨域,前后分离

    前端开发往往涉及到跨域问题,其中解决方案很多: 1.jsonp 需要目标服务器配合一个callback函数. 2.window.name+iframe 需要目标服务器响应window.name. 3. ...

  5. js中window对象的opener属性的一个坑

    2018-05-08 17:48:33 今天我编写代码碰到了一个让我纠结了很久的坑,特别想在此说一下,让其他人避免我踏过的这个坑. 这个坑就是:在我自己写的子窗口中用opener属性却获取不到父窗口的 ...

  6. vue实现淘宝商品详情页属性选择功能

    方法一是自己想出来的,方法二来自忘记哪里看到的了 不知道是不是你要的效果: 方法一:利用input[type="radio"] css代码: input { display: no ...

  7. 七个人生工具:SWOT、PDCA、6W2H、SMART、WBS、时间管理、二八原则

    本文为转载 心理导读:今天为大家分享几个实用的工具,来源网络. SWOT分析法 Strengths:优势 Weaknesses:劣势 Opportunities:机会 Threats:威胁 意义:帮您 ...

  8. Sass快速入门学习笔记

    1. 使用变量; sass让人们受益的一个重要特性就是它为css引入了变量.你可以把反复使用的css属性值 定义成变量,然后通过变量名来引用它们,而无需重复书写这一属性值.或者,对于仅使用过一 次的属 ...

  9. day07

    放完了愚人节的假期后就忘记更新了,这样不好,学习的态度也有点懒散了,需要调整过来,这几天在做一个退款流程,想好了建表.逻辑设计和需求分析,然后就是写具体的代码了,有些东西还是要多学习,不然书到用时方恨 ...

  10. HiJson(Json格式化工具)64位中文版下载 v2.1.2

    链接:https://pan.baidu.com/s/15gMvig15iUjpqSX7nUZ-5Q 密码:8086