HTML5仿微信聊天界面、微信朋友圈实例
这几天使用H5开发了一个仿微信聊天前端界面,尤其微信底部编辑器那块处理的很好,使用HTML5来开发,虽说功能效果并没有微信那么全,但是也相当不错了,可以发送消息、表情,发送的消息自动回滚定位到底部,另外可以对消息、图片、视频有不同的右键处理提示,还有打赏、占屏等操作。
html代码片段:
- <!--BEGIN 打赏-->
- <div class="js_dialog" id="J_Dialog_dashang" style="display: none;">
- <!--<div class="weui-mask"></div>-->
- <div class="weui-dialog">
- <i class="weui-xclose"></i>
- <div class="weui-dialog__bd">
- <!-- //打赏模板区-->
- <div class="ws__popup-template">
- <h2 class="hdTit">为喜欢的节目打赏</h2>
- <div class="item flexbox">
- <input class="ipt-txt align-l flex1" type="text" name="dschooseProgram" placeholder="选择打赏节目" readonly />
- </div>
- <div class="item item-area">
- <textarea class="describe" name="content" placeholder="输入打赏语,30字以内(选填)"></textarea>
- </div>
- <div class="item item-gift" id="J__chooseGift">
- <div class="gift flexbox selected" data-gift="001">
- <label class="txt"><span>豪车</span><em class="time">霸屏50秒</em></label>
- <span class="amount">¥<em>12</em> <i class="chkbox"></i></span>
- </div>
- <div class="gift flexbox" data-gift="002">
- <label class="txt"><span>动人玫瑰</span><em class="time">霸屏20秒</em></label>
- <span class="amount">¥<em>8</em> <i class="chkbox"></i></span>
- </div>
- </div>
- </div>
- </div>
- <div class="weui-dialog__ft">
- <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>
- </div>
- </div>
- </div>
- <!--END 打赏-->
Javascript代码片段:
- /* ——聊天编辑器区域 */
- var $editor = $(".J__editorText"), editor = $editor[0];
- var $face = $(".emotion-area dd img");
- $face.on("click", function(e){
- if($(this).hasClass("face")){ //图像
- var img = $(this)[0].cloneNode(true);
- editor.focus();
- setTimeout(function(){
- var range, node;
- if(document.selection && document.selection.createRange){
- document.selection.createRange().pasteHTML(img);
- }else if(window.getSelection && window.getSelection().getRangeAt){
- range = window.getSelection().getRangeAt(0);
- range.insertNode(img);
- range.collapse(false);
- var sel = window.getSelection();
- sel.removeAllRanges();
- sel.addRange(range);
- }
- }, 16);
- }else if($(this).hasClass("del")){ //删除
- editor.focus();
- range = window.getSelection().getRangeAt(0);
- range.collapse(false);
- var sel = window.getSelection();
- sel.removeAllRanges();
- sel.addRange(range);
- document.execCommand("delete");
- }
- });
- //...格式化编辑器包含标签
- editor.addEventListener("focus", function(evt) {
- surrounds()
- }, true);
- editor.addEventListener("input", function(evt) {
- surrounds();
- }, false);
- function surrounds() {
- setTimeout(function () { //chrome
- var sel = window.getSelection();
- var anchorNode = sel.anchorNode;
- if (!anchorNode) return;
- if (sel.anchorNode === editor ||
- (sel.anchorNode.nodeType === 3 && sel.anchorNode.parentNode === editor)) {
- var range = sel.getRangeAt(0);
- var p = document.createElement("p");
- range.surroundContents(p);
- range.selectNodeContents(p);
- range.insertNode(document.createElement("br")); //chrome
- sel.collapse(p, 0);
- (function clearBr() {
- var elems = [].slice.call(editor.children);
- for (var i = 0, len = elems.length; i < len; i++) {
- var el = elems[i];
- if (el.tagName.toLowerCase() == "br") {
- editor.removeChild(el);
- }
- }
- elems.length = 0;
- })();
- }
- }, 0);
- }
- //...滚动到聊天内容底部
- function scrollToBottom(){
- $('.ws__chatMsg-panel').animate({scrollTop: $("#J__chatMsgList").height()}, 300);
- }
运行效果:
HTML5仿微信聊天界面、微信朋友圈实例的更多相关文章
- HTML5仿手机微信聊天界面
HTML5仿手机微信聊天界面 这篇文章主要为大家详细介绍了HTML5仿手机微信聊天界面的关键代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 给大家带来的是HTML5仿手机微信聊天界面, ...
- android 仿微信聊天界面,以及语音录制功能
extends:http://104zz.iteye.com/blog/1709840 本例为模仿微信聊天界面UI设计,文字发送以及语言录制UI. 1先看效果图: 第一:chat.xml设计 ...
- Android微信逆向--实现发朋友圈动态
0x0 前言 最近一直在研究Windows逆向的东西,想着快要把Android给遗忘了.所以就想利用工作之余来研究Android相关的技术,来保持对Android热情.调用微信代码来发送朋友圈动态一直 ...
- Swift - 自定义单元格实现微信聊天界面
1,下面是一个放微信聊天界面的消息展示列表,实现的功能有: (1)消息可以是文本消息也可以是图片消息 (2)消息背景为气泡状图片,同时消息气泡可根据内容自适应大小 (3)每条消息旁边有头像,在左边表示 ...
- 生成二维码、微信自定义分享到朋友圈、ipa不从应用商店安装
生成二维码网址:http://www.liantu.com/ 微信自定义分享到朋友圈:http://www.cnblogs.com/memor-y/p/6728179.html ipa不从应用商店安装 ...
- Android:日常学习笔记(8)———开发微信聊天界面
Android:日常学习笔记(8)———开发微信聊天界面 只做Nine-Patch图片 Nine-Patch是一种被特殊处理过的PNG图片,能够指定哪些区域可以被拉升,哪些区域不可以.
- ASP调用SDK微信分享好友、朋友圈
ASP调用SDK微信分享好友.朋友圈需要用到sha1.asp,我先来上主代码,然后再附加sha1.asp,方便大家直接复制过去即可使用. 页面:shara.asp 1 <%@LANGUAGE=& ...
- 高仿qq聊天界面
高仿qq聊天界面,给有需要的人,界面效果如下: 真心觉得做界面非常痛苦,给有需要的朋友. chat.xml <?xml version="1.0" encoding=&quo ...
- vue聊天室|h5+vue仿微信聊天界面|vue仿微信
一.项目简介 基于Vue2.0+Vuex+vue-router+webpack2.0+es6+vuePhotoPreview+wcPop等技术架构开发的仿微信界面聊天室——vueChatRoom,实现 ...
随机推荐
- unity零基础开始学习做游戏(二)让你的对象动起来
-------小基原创,转载请给我一个面子 小基认为电子游戏与电影最重要的区别就是交互,如果电子游戏没有让你输入的交互功能的话,全程都"只可远观,而不可鼓捣"的话,你可能是在看视频 ...
- Day4_闭包含数
闭包函数: 闭包函数是在作用域的前提下 闭包含数:定义在函数内部的函数,包含对外部作用域名字的引用,而不是对全局作用域名字的引用,那么该内部函数就称为闭包含数. eg: x=1 def f1(): x ...
- Golang之Context的使用
转载自:http://www.nljb.net/default/Golang%E4%B9%8BContext%E7%9A%84%E4%BD%BF%E7%94%A8/ 简介 在golang中的创建一个新 ...
- nginx 反向代理,支持跨域,前后分离
前端开发往往涉及到跨域问题,其中解决方案很多: 1.jsonp 需要目标服务器配合一个callback函数. 2.window.name+iframe 需要目标服务器响应window.name. 3. ...
- js中window对象的opener属性的一个坑
2018-05-08 17:48:33 今天我编写代码碰到了一个让我纠结了很久的坑,特别想在此说一下,让其他人避免我踏过的这个坑. 这个坑就是:在我自己写的子窗口中用opener属性却获取不到父窗口的 ...
- vue实现淘宝商品详情页属性选择功能
方法一是自己想出来的,方法二来自忘记哪里看到的了 不知道是不是你要的效果: 方法一:利用input[type="radio"] css代码: input { display: no ...
- 七个人生工具:SWOT、PDCA、6W2H、SMART、WBS、时间管理、二八原则
本文为转载 心理导读:今天为大家分享几个实用的工具,来源网络. SWOT分析法 Strengths:优势 Weaknesses:劣势 Opportunities:机会 Threats:威胁 意义:帮您 ...
- Sass快速入门学习笔记
1. 使用变量; sass让人们受益的一个重要特性就是它为css引入了变量.你可以把反复使用的css属性值 定义成变量,然后通过变量名来引用它们,而无需重复书写这一属性值.或者,对于仅使用过一 次的属 ...
- day07
放完了愚人节的假期后就忘记更新了,这样不好,学习的态度也有点懒散了,需要调整过来,这几天在做一个退款流程,想好了建表.逻辑设计和需求分析,然后就是写具体的代码了,有些东西还是要多学习,不然书到用时方恨 ...
- HiJson(Json格式化工具)64位中文版下载 v2.1.2
链接:https://pan.baidu.com/s/15gMvig15iUjpqSX7nUZ-5Q 密码:8086