一个符号插入器 中用到的js代码


Posted in Javascript onSeptember 04, 2007

/**
 * @author tin555
 */
function setHTML(html) {
    ContentEdit.value = html;
        eWebEditor.document.designMode="On";
        eWebEditor.document.open();
        eWebEditor.document.write(html);
        eWebEditor.document.body.contentEditable="true";
        eWebEditor.document.execCommand("2D-Position",true,true);
        eWebEditor.document.execCommand("MultipleSelection", true, true);
        eWebEditor.document.execCommand("LiveResize", true, true);
        eWebEditor.document.close();
    eWebEditor.document.body.onpaste = onPaste ;
    //eWebEditor.document.body.onhelp = onHelp ;
    //eWebEditor.document.body.ondragend = new Function("return doDragEnd();");
    eWebEditor.document.onkeydown = new Function("return onKeyDown(eWebEditor.event);");
    //eWebEditor.document.oncontextmenu=new Function("return showContextMenu(eWebEditor.event);");
    //eWebEditor.document.onmousedown = new Function("return onMouseDown();");
    //eWebEditor.document.onmouseup = new Function("return onMouseUp();");
}

function getHTML() {
    var html;

        html = eWebEditor.document.body.innerHTML;

        if ((html.toLowerCase()=="<p> </p>")||(html.toLowerCase()=="<p></p>")){
            html = "";
        }

    return html;
}

function insertHTML(html) {

    eWebEditor.focus();
    if (eWebEditor.document.selection.type.toLowerCase() != "none"){
        eWebEditor.document.selection.clear() ;
    }
    eWebEditor.document.selection.createRange().pasteHTML(html) ; 
}

function appendHTML(html) {
    if (eWebEditor.document.selection.type.toLowerCase() != "none"){
        eWebEditor.document.selection.clear() ;
    }
        eWebEditor.document.body.innerHTML += html;

}

function doDragEnd(){
    var oSelection = eWebEditor.document.selection.createRange();
    var sRangeType = eWebEditor.document.selection.type;
    if (sRangeType == "Control") {
        var oControl = oSelection.item(0);
        if (oControl.tagName == "IMG"){
            oControl.src = FullPath2SetPath(oControl.src);
        }
    }
    if (sRangeType == "Text") {
        var els = eWebEditor.document.body.getElementsByTagName("IMG");
        var oRngTemp = eWebEditor.document.body.createTextRange();
        for(var i=0;i<els.length;i++){
            oRngTemp.moveToElementText(els(i));
            if (oSelection.inRange(oRngTemp)){
                els(i).src = FullPath2SetPath(els(i).src)
            }
        }
    }

    return true;
}

function onKeyDown(event){
    var n_KeyCode = event.keyCode;
        if (n_KeyCode==13){
                    return false;
        }
}

var oResizing = new Object;
function onMouseDown(){
    oResizing.El = null;
    if (eWebEditor.document.selection.type == "Control") {
        var oControlRange = eWebEditor.document.selection.createRange();
        oResizing.El = oControlRange(0);
        oResizing.W = oResizing.El.style.width;
        oResizing.H = oResizing.El.style.height;
    }

    
}

function GetClipboardHTML() {
    var oDiv = document.getElementById("eWebEditor_Temp_HTML");
    oDiv.innerHTML = "" ;
    var oTextRange = document.body.createTextRange() ;
    oTextRange.moveToElementText(oDiv) ;
    oTextRange.execCommand("Paste") ;

    var sData = oDiv.innerHTML ;
    oDiv.innerHTML = "" ;

    return sData ;
}

function cleanAndPaste( html ) {
    html = html.replace(/<\/?SPAN[^>]*>/gi, "" );
    html = html.replace(/<(\w[^>]*) class=([^ |>]*)([^>]*)/gi, "<$1$3") ;
    html = html.replace(/<(\w[^>]*) style="([^"]*)"([^>]*)/gi, "<$1$3") ;
    html = html.replace(/<(\w[^>]*) lang=([^ |>]*)([^>]*)/gi, "<$1$3") ;
    html = html.replace(/<\\?\?xml[^>]*>/gi, "") ;
    html = html.replace(/<\/?\w+:[^>]*>/gi, "") ;
    html = html.replace(/ /, " " );

    insertHTML( html ) ;
}
function onPaste() {
        var sHTML = GetClipboardHTML() ;
            var re = /<\w[^>]* class="?MsoNormal"?/gi ;
            if ( re.test(sHTML)){
                if ( confirm("你要粘贴的内容好象是从Word中拷出来的,是否要先清除Word格式再粘贴?") ){
                    cleanAndPaste( sHTML ) ;
                    return false ;
                }
                }
}

Javascript 相关文章推荐
angularjs的一些优化小技巧
Dec 06 Javascript
js中this用法实例详解
May 05 Javascript
JavaScript实现的浮动层框架用法实例分析
Oct 10 Javascript
jQuery实现的给图片点赞+1动画效果(附在线演示及demo源码下载)
Dec 31 Javascript
Bootstrap源码解读排版(1)
Dec 23 Javascript
jQuery加载及解析XML文件的方法实例分析
Jan 22 Javascript
深入理解vue中的$set
Jun 01 Javascript
JS实现多物体运动的方法详解
Jan 23 Javascript
解决vue无法设置滚动位置的问题
Oct 07 Javascript
小程序中设置缓存过期的实现方法
Jan 14 Javascript
JavaScript封装单向链表的示例代码
Sep 17 Javascript
js异步接口并发数量控制的方法示例
Nov 22 Javascript
【消息提示组件】,兼容IE6/7&amp;&amp;FF2
Sep 04 #Javascript
一个用js实现控制台控件的代码
Sep 04 #Javascript
科讯商业版中用到的ajax空间与分页函数
Sep 02 #Javascript
PNGHandler-借助JS让PNG图在IE下实现透明(包括背景图)
Aug 31 #Javascript
给Javascript数组插入一条记录的代码
Aug 30 #Javascript
用javascript实现给出的盒子的序列是否可连为一矩型
Aug 30 #Javascript
Expandable &quot;Detail&quot; Table Rows
Aug 29 #Javascript
You might like
PHP读取MySQL数据代码
2008/06/05 PHP
php循环检测目录是否存在并创建(循环创建目录)
2011/01/06 PHP
PHP中的排序函数sort、asort、rsort、krsort、ksort区别分析
2014/08/18 PHP
使用PHP Socket 编程模拟Http post和get请求
2014/11/25 PHP
PHP实现用户异地登录提醒功能的方法【基于thinkPHP框架】
2018/03/15 PHP
php框架CodeIgniter主从数据库配置方法分析
2018/05/25 PHP
php用户名的密码加密更安全的方法
2019/06/21 PHP
SwfUpload在IE10上不出现上传按钮的解决方法
2013/06/25 Javascript
为Javascript中的String对象添加去除左右空格的方法(示例代码)
2013/11/30 Javascript
Javascript冒泡排序算法详解
2014/12/03 Javascript
javascript中一些util方法汇总
2015/06/10 Javascript
JS提交form表单实例分析
2015/12/10 Javascript
详解各版本React路由的跳转的方法
2018/05/10 Javascript
Vue中添加滚动事件设置的方法详解
2020/09/14 Javascript
vue使用screenfull插件实现全屏功能
2020/09/17 Javascript
[43:47]DOTA2上海特级锦标赛主赛事日 - 4 败者组第四轮#2 MVP.Phx VS Fnatic第一局
2016/03/05 DOTA
实例讲解Python中global语句下全局变量的值的修改
2016/06/16 Python
Python中的上下文管理器和with语句的使用
2018/04/17 Python
python列表使用实现名字管理系统
2019/01/30 Python
python设置环境变量的原因和方法
2019/06/24 Python
Python机器学习算法库scikit-learn学习之决策树实现方法详解
2019/07/04 Python
python爬虫之快速对js内容进行破解
2019/07/09 Python
Pytorch转keras的有效方法,以FlowNet为例讲解
2020/05/26 Python
终于搞懂了Keras中multiloss的对应关系介绍
2020/06/22 Python
python如何查看安装了的模块
2020/06/23 Python
Python Selenium实现无可视化界面过程解析
2020/08/25 Python
加拿大健康、婴儿和美容产品在线购物:Well.ca
2016/11/30 全球购物
英语专业学生的自我评价
2013/12/30 职场文书
美容院店长岗位职责
2014/04/08 职场文书
学习型班组申报材料
2014/05/31 职场文书
预防艾滋病宣传活动总结
2015/05/09 职场文书
公司员工离职感言
2015/08/03 职场文书
OpenCV-Python实现怀旧滤镜与连环画滤镜
2021/06/09 Python
比较几种Redis集群方案
2021/06/21 Redis
Python通过loop.run_in_executor执行同步代码 同步变为异步
2022/04/11 Python
微信小程序 WeUI扩展组件库的入门教程
2022/04/21 Javascript