一个符号插入器 中用到的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函数中的arguments参数
Aug 01 Javascript
网页编辑器ckeditor和ckfinder配置步骤分享
May 24 Javascript
jQuery UI 实现email输入提示实例
Aug 15 Javascript
关闭时刷新父窗口两种方法
May 07 Javascript
JavaScript事件 &quot;事件对象&quot;的注意要点
Jan 14 Javascript
JavaScript函数柯里化详解
Apr 29 Javascript
原生js实现对Ajax的封装(仿jquery)
Jan 22 Javascript
vue-router路由与页面间导航实例解析
Nov 07 Javascript
Vue下路由History模式打包后页面空白的解决方法
Jun 29 Javascript
react在安卓中输入框被手机键盘遮挡问题的解决方法
Sep 03 Javascript
jQuery实现合并表格单元格中相同行操作示例
Jan 28 jQuery
element-ui上传一张图片后隐藏上传按钮功能
May 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 5.0对象模型深度探索之类的静态成员
2008/03/27 PHP
深入mysql_fetch_row()与mysql_fetch_array()的区别详解
2013/06/05 PHP
destoon会员注册提示“数据校验失败(2)”解决方法
2014/06/21 PHP
PHP使用GETDATE获取当前日期时间作为一个关联数组的方法
2015/03/19 PHP
use jscript List Installed Software
2007/06/11 Javascript
分享几个超级震憾的图片特效
2012/01/08 Javascript
jquery控制左右箭头滚动图片列表的实例
2013/05/20 Javascript
js中typeof的用法汇总
2013/12/12 Javascript
node.js中的buffer.copy方法使用说明
2014/12/14 Javascript
js函数与php函数的区别实例浅析
2015/01/12 Javascript
jQuery实现新消息在网页标题闪烁提示
2015/06/23 Javascript
JavaScript实现的伸展收缩型菜单代码
2015/10/14 Javascript
jQuery Validate表单验证深入学习
2015/12/18 Javascript
vue.js事件处理器是什么
2017/03/20 Javascript
bootstrap-table组合表头的实现方法
2017/09/07 Javascript
vue移动端监听滚动条高度的实现方法
2018/09/03 Javascript
JavaScript显式数据类型转换详解
2019/03/18 Javascript
JavaScript变量作用域及内存问题实例分析
2019/06/10 Javascript
在vue中根据光标的显示与消失实现下拉列表
2019/09/29 Javascript
js 获取本周、上周、本月、上月、本季度、上季度的开始结束日期
2020/02/01 Javascript
vue下拉刷新组件的开发及slot的使用详解
2020/12/23 Vue.js
[01:02:07]Liquid vs Newbee 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
Python函数式编程指南(二):从函数开始
2015/06/24 Python
Python进阶学习之特殊方法实例详析
2017/12/01 Python
Python将图片转换为字符画的方法
2020/06/16 Python
基于python框架Scrapy爬取自己的博客内容过程详解
2019/08/05 Python
python 消费 kafka 数据教程
2019/12/21 Python
python opencv角点检测连线功能的实现代码
2020/11/24 Python
美国知名生活购物网站:Goop
2017/11/03 全球购物
Spartoo瑞典:鞋子、包包和衣服
2018/09/15 全球购物
个人求职信范例
2014/01/29 职场文书
软环境建设心得体会
2014/09/09 职场文书
个人作风纪律整顿整改措施
2014/10/25 职场文书
成本会计岗位职责
2015/02/03 职场文书
自荐信格式模板
2015/03/27 职场文书
预备党员介绍人意见
2015/06/01 职场文书