HTML5仿微信聊天界面和朋友圈代码

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

html代码片段:

<!--BEGIN 打赏-->
<p class=js_dialog id=J_Dialog_dashang style=display: none;>
    <!--<p class=weui-mask></p>-->
    <p class=weui-dialog>
        <i class=weui-xclose></i>
        <p class=weui-dialog__bd>
            <!-- //打赏模板区-->
            <p class=ws__popup-template>
                <h2 class=hdTit>为喜欢的节目打赏</h2>
                <p class=item flexbox>
                    <input class=ipt-txt align-l flex1 type=text name=dschooseProgram placeholder=选择打赏节目 readonly />
                </p>
                <p class=item item-area>
                    <textarea class=describe name=content placeholder=输入打赏语,30字以内(选填)></textarea>
                </p>
                <p class=item item-gift id=J__chooseGift>
                    <p 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>
                    </p>
                    <p 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>
                    </p>
                </p>
            </p>
        </p>
        <p 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>
        </p>
    </p>
</p>
<!--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);
}

运行效果:
 

相关推荐:

AngularJS仿微信图片手势缩放代码

jquery仿微信聊天界面实例分享

实例讲解CSS3仿微信聊天气泡的方法

以上就是HTML5仿微信聊天界面和朋友圈代码的详细内容,更多请关注云资源网其它相关文章!

原文链接:https://www.sudo1.com

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
8. 精力有限,不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别
9.本站默认解压密码为:www.sudo1.com
本站提供的一切软件、教程和内容信息仅限用于学习和研究目的。
不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。
本站信息来自网络收集整理,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑或手机中彻底删除上述内容。
如果您喜欢该程序和内容,请支持正版,购买注册,得到更好的正版服务。
我们非常重视版权问题,如有侵权请邮件与我们联系处理。敬请谅解!

云资源网 » HTML5仿微信聊天界面和朋友圈代码

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
提示下载完但解压或打开不了?
最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。 若排除这种情况,可在对应资源底部留言,或 联络我们.。
你们有qq群吗怎么加入?
当然有的,如果你是帝国cms、易优cms、和pbootcms系统的爱好者你可以加入我们的QQ千人交流群https://www.sudo1.com/page-qun.html。
  • 会员数(个)
  • 12334资源数(个)
  •        
  • 资源(G)
  •        
  • 今日下载
  • 1418稳定运行(天)

提供最优质的资源集合

立即查看 了解详情