zoukankan      html  css  js  c++  java
  • 可编辑DIV (contenteditable="true") 在鼠标光标处插入图片或者文字

    近期需开发一个DIV做的编辑器,插入表情图片可直接预览效果,仔细参考了下百度贴吧的过滤粘贴过来文件的THML代码,自己整理了下。写出来只是和大家分享下,我自己也不大懂,经过努力,幸好搞定。

    蛋疼的事情出来了,当编辑框失去焦点时候,再插入图片时候总是插入在最前面(谷歌和火狐,IE没问题)。还没搞定,,,

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
    
    <html xmlns="http://www.w3.org/1999/xhtml"> 
    
    <head> 
    
    <meta http-equiv="Content-Language" content="zh-cn" /> 
    
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
    
    <title>DIV可编辑框鼠标光标处插入图片或者文字。</title>
    
    <script type="text/javascript" src="http://www.w3school.com.cn/jquery/jquery.js
    
    "></script>
    
    <script type="text/javascript">
    
    $(function(){
    
        $(".imgbox img").click(function(){
    
        $("#testdiv").focus();
    
        var sy = $(".imgbox img").index(this) + 1;
    
        var img_url = "<img src='faceimg/"+sy+".gif'>";
    
      
    
    /*此处如果不是插入图片可这样:
    
    var img_url = "插入测试的文字";
    
    */
    
        _insertimg(img_url);
    
     
    
        })
    
    //注:如果要插入的是那种“快捷发言,快捷留言”里的文字,只需把那些文字都分别放在A标签里即可,然后img_url=a标签里面的内容。工作中的编辑器终于搞定!能插入图片和快捷发言和表情图片等。
    
    })
    
     
    
     
    
    //监控粘贴(ctrl+v),如果是粘贴过来的东东,则替换多余的html代码,只保留<br>
    
    function pasteHandler(){
    
    setTimeout(function(){
    
    var content = document.getElementById("testdiv").innerHTML;
    
    valiHTML=["br"]; 
    
    content=content.replace(/_moz_dirty=""/gi, "").replace(/[/g, "[[-").replace(/]/g, "-]]").replace(/</ ?tr[^>]*>/gi, "[br]").replace(/</ ?td[^>]*>/gi, "&nbsp;&nbsp;").replace(/<(ul|dl|ol)[^>]*>/gi, "[br]").replace(/<(li|dd)[^>]*>/gi, "[br]").replace(/<p [^>]*>/gi, "[br]").replace(new RegExp("<(/?(?:" + valiHTML.join("|") + ")[^>]*)>", "gi"), "[$1]").replace(new RegExp('<span([^>]*class="?at"?[^>]*)>', "gi"), "[span$1]").replace(/<[^>]*>/g, "").replace(/[[-/g, "[").replace(/-]]/g, "]").replace(new RegExp("\[(/?(?:" + valiHTML.join("|") + "|img|span)[^\]]*)\]", "gi"), "<$1>");
    
    if(!$.browser.mozilla){
    
    content=content.replace(/
    ?
    /gi, "<br>");
    
    }
    
    document.getElementById("testdiv").innerHTML=content;
    
    },1)
    
      
    
    }
    
     
    
    //锁定编辑器中鼠标光标位置。。
    
    function _insertimg(str){
    
    var selection= window.getSelection ? window.getSelection() : document.selection;
    
    var range= selection.createRange ? selection.createRange() : selection.getRangeAt(0);
    
    if (!window.getSelection){
    
    document.getElementById('testdiv').focus();
    
    var selection= window.getSelection ? window.getSelection() : document.selection;
    
    var range= selection.createRange ? selection.createRange() : selection.getRangeAt(0);
    
    range.pasteHTML(str);
    
    range.collapse(false);
    
    range.select();
    
    }else{
    
    document.getElementById('testdiv').focus();
    
    range.collapse(false);
    
    var hasR = range.createContextualFragment(str);
    
    var hasR_lastChild = hasR.lastChild;
    
    while (hasR_lastChild && hasR_lastChild.nodeName.toLowerCase() == "br" && hasR_lastChild.previousSibling && hasR_lastChild.previousSibling.nodeName.toLowerCase() == "br") {
    
    var e = hasR_lastChild;
    
    hasR_lastChild = hasR_lastChild.previousSibling;
    
    hasR.removeChild(e)
    
    }                                
    
    range.insertNode(hasR);
    
    if (hasR_lastChild) {
    
    range.setEndAfter(hasR_lastChild);
    
    range.setStartAfter(hasR_lastChild)
    
    }
    
    selection.removeAllRanges();
    
    selection.addRange(range)
    
    }
    
    }
    
     
    
    //监控按enter键和空格键,如果按了enter键,则取消原事件,用<BR/ >代替。此处还等待修改!!!!!!如果后端能实现各个浏览器回车键产生的P,div, br的输出问题话就无需采用这段JS、
    
    function enterkey(){ 
    
    e = event.keyCode; 
    
    if (e==13||e==32) { 
    
       var keyCode = event.keyCode ? event.keyCode : event.which ? event.which : event.charCode;
    
       event.returnValue = false;  // 取消此事件的默认操作 
    
       if(document.selection && document.selection.createRange){
    
        var myRange = document.selection.createRange();
    
        myRange.pasteHTML('<br />');
    
        }else if(window.getSelection){
    
    var selection = window.getSelection();
    
    var range = window.getSelection().getRangeAt(0);
    
    range.deleteContents();
    
    var newP = document.createElement('br');
    
    range.insertNode(newP);
    
    }
    
    //alert(document.getElementById("testdiv").innerHTML)
    
    } 
    
    } 
    
    </script>
    
    <style type="text/css">
    
    .editbox{width:400px;height:200px;border:1px solid #000; overflow-x:hidden; overflow-y:auto; outline:none;}
    
    .editbox img{ margin:0 3px; display:inline;}
    
    </style>
    
    </head> 
    
    <body>
    
    <div id="testdiv" contenteditable="true" class="editbox" onkeydown="enterkey()" >可以在任意文字后面插入图片或者文字哦!<br /></div>
    
    <div class="imgbox">
    
      <img src="faceimg/1.gif">
    
      <img src="faceimg/2.gif">
    
      <img src="faceimg/3.gif">
    
      <img src="faceimg/4.gif">
    
    </div>
    
       
    
            
    
     
    
    <script type="text/javascript">
    
    //此处必须防止在最下端。
    
    var edt = document.getElementById("testdiv");
    
    if(edt.addEventListener){
    
    edt.addEventListener("paste",pasteHandler,false);
    
    }else{
    
    edt.attachEvent("onpaste",pasteHandler);
    
    }
    
    </script>
    
    </body>
    
    </html>

    转载地址:http://hi.baidu.com/louve01/item/efb14e1add258f6b3f87cedb

  • 相关阅读:
    vue----webpack模板----axios请求
    vue-----meta路由元信息
    vue----webpack模板----全局路由守卫
    vue----webpack模板----局部路由守卫
    vue----webpack模板----组件复用解决方法
    vue----webpack模板----编程式导航
    vue----webpack模板----路由跳转的3中方式
    vue----webpack模板----路由传值
    vue----webpack模板----children子路由,路由嵌套
    vue----webpack模板----路由配置项
  • 原文地址:https://www.cnblogs.com/kongxs/p/4121123.html
Copyright © 2011-2022 走看看