一个符号插入器 中用到的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 相关文章推荐
javascript引用对象的方法
Jan 11 Javascript
jQuery ctrl+Enter shift+Enter实现代码
Feb 07 Javascript
基于Jquery的开发个代阴影的对话框效果代码
Jul 28 Javascript
js自动生成的元素与页面原有元素发生堆叠的解决方法
Sep 04 Javascript
JavaScript处理解析JSON数据过程详解
Sep 11 Javascript
JS组件Bootstrap ContextMenu右键菜单使用方法
Apr 17 Javascript
仿iframe效果Aajx文件上传实例
Nov 18 Javascript
angular ng-model 无法获取值的处理方法
Oct 02 Javascript
JavaScript学习笔记之DOM基础操作实例小结
Jan 09 Javascript
微信小程序云开发如何使用云函数生成二维码
May 18 Javascript
使用layui监听器监听select下拉框,事件绑定不成功的解决方法
Sep 28 Javascript
vue实现五子棋游戏
May 28 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项目开发中最常用的自定义函数整理
2010/12/02 PHP
str_replace只替换一次字符串的方法
2013/04/09 PHP
PHP的变量类型和作用域详解
2014/03/12 PHP
php实现获取文章内容第一张图片的方法
2014/11/04 PHP
PHP Oauth授权和本地加密实现方法
2016/08/12 PHP
PHP运行模式汇总
2016/11/06 PHP
Linux下安装Memcached服务器和客户端与PHP使用示例
2019/04/15 PHP
用正则xmlHttp实现的偷(转)
2007/01/22 Javascript
让浏览器非阻塞加载javascript的几种方法小结
2011/04/25 Javascript
dotopAlert 提示用户需安装播放器的代码
2012/09/17 Javascript
js的Prototype属性解释及常用方法
2014/05/08 Javascript
JavaScript合并两个数组并去除重复项的方法
2015/06/13 Javascript
text-align:justify实现文本两端对齐 兼容IE
2015/08/19 Javascript
IE6-IE9使用JSON、table.innerHTML所引发的问题
2015/12/22 Javascript
AngularJS实现树形结构(ztree)菜单示例代码
2016/09/18 Javascript
JavaScript实现时钟滴答声效果
2017/01/29 Javascript
三步搞定:Vue.js调用Android原生操作
2020/09/07 Javascript
Vue封装Axios请求和拦截器的步骤
2020/09/16 Javascript
JavaScript实现网页动态生成表格
2020/11/25 Javascript
[02:45]DOTA2英雄敌法师基础教程
2013/11/25 DOTA
python多线程抓取天涯帖子内容示例
2014/04/03 Python
Python操作MySQL模拟银行转账
2018/03/12 Python
对python自动生成接口测试的示例讲解
2018/11/30 Python
Pandas之排序函数sort_values()的实现
2019/07/09 Python
python numpy 矩阵堆叠实例
2020/01/17 Python
python3实现语音转文字(语音识别)和文字转语音(语音合成)
2020/10/14 Python
Python基于tkinter canvas实现图片裁剪功能
2020/11/05 Python
Hunter Boots美国官方网站:赫特威灵顿雨靴
2018/06/16 全球购物
介绍一下javax.servlet.Servlet接口及其主要方法
2015/11/30 面试题
网管求职信
2014/03/03 职场文书
2014年小学语文工作总结
2014/12/20 职场文书
2016年3月份红领巾广播稿
2015/12/21 职场文书
如何用Node.js编写内存效率高的应用程序
2021/04/30 Javascript
Python下opencv使用hough变换检测直线与圆
2021/06/18 Python
原生JavaScript实现简单五子棋游戏
2021/06/28 Javascript
Windows Server 2022 超融合部署(图文教程)
2022/06/25 Servers