一个符号插入器 中用到的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 相关文章推荐
jQuery 对象中的类数组操作
Apr 27 Javascript
js 对联广告、漂浮广告封装类(IE,FF,Opera,Safari,Chrome
Nov 26 Javascript
Javascript动态创建div的方法
Feb 09 Javascript
jQuery的css() 方法使用指南
May 03 Javascript
jQuery可见性过滤器:hidden和:visibility用法实例
Jun 24 Javascript
jquery easyui dataGrid动态改变排序字段名的方法
Mar 02 Javascript
Vue.js实战之使用Vuex + axios发送请求详解
Apr 04 Javascript
Node学习记录之cluster模块
May 31 Javascript
JS计算两个数组的交集、差集、并集、补集(多种实现方式)
May 21 Javascript
JavaScript实现简单的计算器
Jan 16 Javascript
Vue-router编程式导航的两种实现代码
Mar 04 Vue.js
vue路由实现登录拦截
Mar 24 Vue.js
【消息提示组件】,兼容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面向对象程序设计之类常量用法实例
2014/08/20 PHP
用于判断用户注册时,密码强度的JS代码
2009/01/01 Javascript
ASP.NET MVC中EasyUI的datagrid跨域调用实现代码
2012/03/14 Javascript
jquery插件制作 图片走廊 gallery
2012/08/17 Javascript
jquery 面包屑导航 具体实现
2013/06/05 Javascript
Javascript 命名空间模式
2013/11/01 Javascript
js仿土豆网带缩略图的焦点图片切换效果实现方法
2015/02/23 Javascript
基于jquery步骤进度条源码分享
2015/11/12 Javascript
JS弹出新窗口被拦截的解决方法
2016/08/09 Javascript
jQuery实现文章图片弹出放大效果
2017/04/06 jQuery
js 数字、字符串、布尔值的转换方法(必看)
2017/04/07 Javascript
JS判断数组那点事
2017/10/10 Javascript
react 实现页面代码分割、按需加载的方法
2018/04/03 Javascript
微信小程序实现红包雨功能
2018/07/11 Javascript
解决vue keep-alive 数据更新的问题
2018/09/21 Javascript
Vue父组件如何获取子组件中的变量
2019/07/24 Javascript
javascript运行机制之执行顺序理解
2020/08/03 Javascript
JavaScript 几种循环方式以及模块化的总结
2020/09/03 Javascript
跟老齐学Python之从if开始语句的征程
2014/09/14 Python
Python开发中爬虫使用代理proxy抓取网页的方法示例
2017/09/26 Python
Python设计模式之策略模式实例详解
2019/01/21 Python
详解django实现自定义manage命令的扩展
2019/08/13 Python
pytorch torch.expand和torch.repeat的区别详解
2019/11/05 Python
Python面向对象魔法方法和单例模块代码实例
2020/03/25 Python
新奇的小玩意:IWOOT
2016/07/21 全球购物
村委会主任先进事迹
2014/01/15 职场文书
好矿嫂事迹材料
2014/01/21 职场文书
团委竞选演讲稿
2014/04/24 职场文书
安全教育月活动总结
2014/05/05 职场文书
学习雷锋精神活动总结
2015/02/06 职场文书
公司酒会致辞
2015/07/30 职场文书
pytorch中的model.eval()和BN层的使用
2021/05/22 Python
python之np.argmax()及对axis=0或者1的理解
2021/06/02 Python
在Spring-Boot中如何使用@Value注解注入集合类
2021/08/02 Java/Android
mysql分组后合并显示一个字段的多条数据方式
2022/01/22 MySQL
Python装饰器详细介绍
2022/03/25 Python