asp.net 在线富文本编辑器

公司做的项目需要用到文本上传功能。

Chrome+IE默认支持粘贴剪切板中的图片,但是我要粘贴的文章存在word里面,图片多达数十张,我总不能一张一张复制吧 ​?

我希望打开文档doc直接复制粘贴到富文本编辑器,直接发布 ​

网上找了很久,大部分都有一些不成熟的问题,皇天不负有心人终于让我找到了一个成熟的项目。

1、只粘贴图片并上传到服务器

https://dwz.cn/ORcEz9fz

config.extraPlugins = 'uploadimage';
//config.uploadUrl = '上传路径';
config.imageUploadUrl= '上传路径';
请求
文件上传的默认请求是一个文件,作为具有“upload”字段的表单数据。

响应:文件已成功上传
当文件成功上传时的JSON响应:

uploaded- 设置为1。
fileName - 上传文件的名称。
url - 上传文件的URL。
响应:文件无法上传
uploaded- 设置为0。
error.message - 要显示给用户的错误消息。
2、粘贴word里面的图片路径是fill://D 这种格式 我理解这种是非浏览器安全的 许多浏览器也不支持

目前项目是用了一种变通的方式:

先把word上传到后台 、poi解析、存储图片 、转换html、替换图片、放到富文本框里显示

(富文本显示有个坑:没找到直接给富文本赋值的方法 要先销毁 记录下

success : function(data) {
     $('#content').attr('value',data.imagePath);
     var editor = CKEDITOR.instances["content"]; //你的编辑器的"name"属性的值
     if (editor) { 
       editor.destroy(true);//销毁编辑器
      }       
     CKEDITOR.replace('content'); //替换编辑器,editorID为ckeditor的"id"属性的值
     $("#content").val(result);    //对editor赋值
     //CKEDITOR.instances.contentCkeditor.setData($("#content").text());
 }

前端效果:

asp.net 在线富文本编辑器_第1张图片 ​

 

接下来就看一下具体操作吧

1、打开工程:

对于文档的上传我们需要知道这个项目的逻辑是否符合我们的构造。

运行:

asp.net 在线富文本编辑器_第2张图片 ​ 

尝试使用文档复制后粘贴进来:

asp.net 在线富文本编辑器_第3张图片 ​ 

asp.net 在线富文本编辑器_第4张图片 ​ 

 

通过粘贴后,文档以及图片被粘贴进来了,看看html代码是否如我们的预期:

asp.net 在线富文本编辑器_第5张图片 ​ 

看来这个工程完全符合我们的预期,图片全部使用img标签统一。传输进度条的效果超出了我的意料。

来看看我们的文档图片被放置在哪了:

asp.net 在线富文本编辑器_第6张图片 ​ 

地址:D:\wamp64\www\WordPasterCKEditor4x\php\upload\201904\16

图片被统一放置在文件夹。

由此看来这个项目的实际效果大大超出了我的意料了,带入工程后完美的优化了工程项目,商业前景非常好啊!

工程目录截图:

asp.net 在线富文本编辑器_第7张图片 ​

wordpaster源代码:

/*
    DEMO地址:https://dwz.cn/ORcEz9fz    
    版权所有 2009-2015 荆门泽优软件有限公司 保留所有版权。
    邮箱:[email protected]
    描述:Word图片上传控件
    此文件实现上传后自动关闭上传窗口的功能
    更新记录:
        2012-07-04 增加对IE9的支持。
*/

//系统错误
var WordPasterError = {
      "0": "连接服务器错误"
    , "1": "发送数据错误"
    , "2": "接收数据错误"
    , "3": "未设置文件路径"
    , "4": "本地文件不存在"
    , "5": "打开本地文件错误"
    , "6": "不能读取本地文件"
    , "7": "公司未授权"
    , "8": "未设置IP"
    , "9": "域名未授权"
    , "10": "文件大小超出限制"
    , "11": "不能设置回调函数"
    , "12": "Native控件错误"
};
var WordPasterConfig = {
    "EncodeType"            : "GB2312"
    , "Company"                : "荆门泽优软件有限公司"
    , "Version"                : "1,5,123,31671"
    , "License"                : ""
    , "Debug"                : false//调试模式
    , "LogFile"                : "f:\\log.txt"//日志文件路径
    , "PasteWordType"        : ""    //粘贴WORD的图片格式。JPG/PNG/GIF/BMP,推荐使用JPG格式,防止出现大图片。
    , "PasteImageType"        : ""    //粘贴文件,剪帖板的图片格式,为空表示本地图片格式。JPG/PNG/GIF/BMP
    , "JpgQuality"            : "100"    //JPG质量。0~100
    , "QueueCount"            : "5"    //同时上传线程数
    , "CryptoType"            : "uuid"//名称计算方式,md5,crc,sha1,uuid,其中uuid为随机名称
    , "ThumbWidth"            : "0"    //缩略图宽度。0表示不使用缩略图
    , "ThumbHeight"            : "0"    //缩略图高度。0表示不使用缩略图
    , "AppPath"                : ""
    , "Cookie"                : ""
    , "Servers"             :[{"url":"www.ncmem.com"},{"url":"www.xproerui.com"}]//内部服务器地址(不下载此地址中的图片)
    , "IcoError"            : "http://www.ncmem.com/products/word-imagepaster/fckeditor2461/WordPaster/error.png"
    , "IcoUploader"         : "http://www.ncmem.com/products/word-imagepaster/fckeditor2461/WordPaster/upload.gif"
    , "PostUrl"                : "http://www.ncmem.com/products/word-imagepaster/fckeditor2461/asp.net/upload.aspx"
    //x86
    , "ClsidParser"            : "2404399F-F06B-477F-B407-B8A5385D2C5E"
    , "CabPath"                : "http://www.ncmem.com/download/WordPaster2/WordPaster.cab"
    //x64
    , "ClsidParser64"        : "7C3DBFA4-DDE6-438A-BEEA-74920D90764B"
    , "CabPath64"            : "http://www.ncmem.com/download/WordPaster2/WordPaster64.cab"
    //Firefox
    , "XpiType"                : "application/npWordPaster2"
    , "XpiPath"                : "http://www.ncmem.com/download/WordPaster2/WordPaster.xpi"
    //Chrome
    , "CrxName"                : "npWordPaster2"
    , "CrxType"                : "application/npWordPaster2"
    , "CrxPath"                : "http://www.ncmem.com/download/WordPaster2/WordPaster.crx"
    //Chrome 45
    , "NatHostName"         : "com.xproer.wordpaster"//
    , "ExtensionID"         : "nmopflahkgegkgkfnhdjpflfjipkpjpk"
    , "NatPath"                : "http://www.ncmem.com/download/WordPaster2/WordPaster.nat.crx"
    , "ExePath"                : "http://www.ncmem.com/download/WordPaster2/WordPaster.exe"
};
function debugMsg(m) { $("#msg").append(m);}
var WordPasterActiveX = {
      "WordParser"        : "Xproer.WordParser2"
    //x64
    , "WordParser64"    : "Xproer.WordParser2x64"
};

//浏览器版本
var BrowserVersion = {
    IE: 0
    , IE64: 1
    , Firefox: 2
    , Chrome: 3
};
var WordPasteImgType = {local:0/*本地图片*/,network:1/*网络图片*/,word:2/*word图片*/};

/*
    上传对象管理器
    关联HTML元素:
        文件上传列表:FilePostLister
        文件上传列表项模板:UploaderTemplate
        文件上传列表分隔线:FilePostLine
*/
function WordPasterManager()
{
    var _this = this;
    this.Editor = null;
    this.Fields = {}; //符加信息
    this.UploadDialogCreated = false;
    this.PasteDialogCreated = false;
    this.imgPasterDlg = null;//jquery obj
    this.imgUploaderDlg = null;//jquery obj
    this.imgIco = null;//jquery obj
    this.imgMsg = null;//jquery obj
    this.imgPercent = null;//jquery obj
    this.ffPaster = null;
    this.ieParser = null;
    this.setuped = false;//控件是否安装
    this.natInstalled = false;
    this.filesPanel = null;//jquery obj
    this.fileItem = null;//jquery obj
    this.line = null;//jquery obj
    this.BrowserVer = BrowserVersion.IE;
    this.ActiveX = WordPasterActiveX;
    this.Config = WordPasterConfig;
    this.EditorContent = ""; //编辑器内容。当图片上传完后需要更新此变量值
    this.CurrentUploader = null; //当前上传项。
    this.UploaderList = new Object(); //上传项列表
    //已上传图片列表
    //模型:LocalUrl:ServerUrl
    this.UploaderListCount = 0; //上传项总数
    this.fileMap = new Object();//文件映射表。
    this.postType = WordPasteImgType.word;//默认是word
    this.working = false;//正在上传中
    this.event = {
        "postComplete": function (url) { }
        , "queueComplete": function () { }
    };

    //IE浏览器信息管理对象
    this.BrowserIE = {
        "GetHtml": function ()
        {
            /*ActiveX的静态加载方式,如果在框架页面中使用此控件,推荐使用静态加截方式。
            
*/ var acx = '
'; //Word解析组件 acx += ' '; return html; } , "Check": function () { var mimetype = navigator.mimeTypes; if (typeof mimetype == "object" && mimetype.length) { for (var i = 0; i < mimetype.length; i++) { var exist = mimetype[i].type == _this.Config["XpiType"];//low ff if(!exist) exist = mimetype[i].type == _this.Config["XpiType"].toLowerCase();//high ff if(exist) return mimetype[i].enabledPlugin; } } else { mimetype = [_this.Config["XpiType"]]; } if (mimetype) { return mimetype.enabledPlugin; } return false; } , "CheckVer": function () { try { return _this.ffPaster.Version != _this.Config["Version"]; } catch (e) { return true;} }//安装插件 , "Setup": function () { var xpi = new Object(); xpi["Calendar"] = _this.Config["XpiPath"]; InstallTrigger.install(xpi, function (name, result) { }); } , "Init": function () { } }; //Chrome浏览器信息管理对象 this.BrowserChrome = { "GetHtml": function () { var html = ''; return html; } , "Check": function () { for (var i = 0, l = navigator.plugins.length; i < l; i++) { if (navigator.plugins[i].name == _this.Config["CrxName"]) { return true; } } return false; } , "CheckVer": function () { try { return _this.ffPaster.Version != _this.Config["Version"]; } catch (e) { return true; } } //安装插件 , "Setup": function () { document.write(''); } , "Init": function () { } }; this.BrowserNat = { "GetHtml": function () { var html = ''; return html; } , "Check": function () { var img = document.createElement('img'); img.src = 'chrome-extension://' + _this.Config.ExtensionID + '/icon.jpg'; img.onload = function () { _this.natInstalled = true; }; img.onerror = function () { _this.setupTip(); }; //chrome.management.get(_this.Config.ExtensionID, function (exInf) { _this.natInstall = true; }); return true; } , "CheckVer": function () { return false; } //安装插件 , "Setup": function () { document.write(''); } , "Init": function (){} }; //WordParser Control this.WordParserIE = { "Init": function () { if (!_this.Browser.Check()) return; this.parser = _this.ieParser; var param = { config: _this.Config, fields: _this.Fields }; this.parser.Init(JSON.stringify(param)); this.parser.StateChanged = _this.WordParser_StateChanged; } , "Paste": function () { if (_this.working) return; _this.working = true; _this.ieParser.Paste() } , "PasteAuto": function (html) { if (_this.working) return; _this.working = true; _this.ieParser.PasteAuto(html) } , "HasData": function () { return _this.ieParser.HasData();} }; this.WordParserFF = { "Init": function () { if (!_this.Browser.Check()) return; this.parser = _this.ffPaster; var param = { config: _this.Config, fields: _this.Fields }; this.parser.Init(JSON.stringify(param)); this.parser.StateChanged = _this.WordParser_StateChanged; } , "Paste": function () { if (_this.working) return; _this.working = true; _this.ffPaster.Paste(); } , "PasteAuto": function (html) { if (_this.working) return; _this.working = true; _this.ffPaster.PasteAuto(html) } , "HasData": function () { return _this.ffPaster.HasData(); } }; //chrome 45 Native Message this.WordParserNat = { "entID": "WordPasterEvent" ,"Init": function () { this.exitEvent(); document.addEventListener('WordPasterEventCallBack', function (evt) { _this.WordParser_StateChanged(JSON.stringify(evt.detail)); }); } , "Paste": function () { if (_this.working) return; _this.working = true; var par = { name: 'Paste', config: _this.Config, fields: _this.Fields }; var evt = document.createEvent("CustomEvent"); evt.initCustomEvent(this.entID, true, false, par); document.dispatchEvent(evt); } , "PasteAuto": function (html) { if (_this.working) return; _this.working = true; var par = { name: 'PasteAuto', data: html,config: _this.Config, fields: _this.Fields }; var evt = document.createEvent("CustomEvent"); evt.initCustomEvent(this.entID, true, false, par); document.dispatchEvent(evt); } , "exit": function () { var par = { name: 'exit'}; var evt = document.createEvent("CustomEvent"); evt.initCustomEvent(this.entID, true, false, par); document.dispatchEvent(evt); } , "exitEvent": function () { var obj = this; $(window).bind("beforeunload", function () { obj.exit(); }); } }; this.WordParser = this.WordParserIE; this.Browser = this.BrowserIE; var browserName = navigator.userAgent.toLowerCase(); this.ie = browserName.indexOf("msie") > 0; //IE11 this.ie = this.ie ? this.ie : browserName.search(/(msie\s|trident.*rv:)([\w.]+)/) != -1; this.firefox = browserName.indexOf("firefox") > 0; this.chrome = browserName.indexOf("chrome") > 0; this.chrome45 = false; this.chrVer = navigator.appVersion.match(/Chrome\/(\d+)/); if (this.ie) { //Win64 if (window.navigator.platform == "Win64") { _this.BrowserVer = BrowserVersion.IE64; _this.Config["ClsidParser"] = this.Config["ClsidParser64"]; _this.Config["CabPath"] = this.Config["CabPath64"]; //ActiveX _this.ActiveX["WordParser"] = this.ActiveX["WordParser64"]; } } //Firefox else if (this.firefox) { _this.BrowserVer = BrowserVersion.Firefox; _this.Browser = this.BrowserFF; this.WordParser = this.WordParserFF; } //chrome else if (this.chrome) { _this.BrowserVer = BrowserVersion.Chrome; _this.Config["XpiPath"] = _this.Config["CrxPath"]; _this.Config["XpiType"] = _this.Config["CrxType"]; _this.Browser = this.BrowserChrome; this.WordParser = this.WordParserFF; //44+版本使用Native Message if (parseInt(this.chrVer[1]) >= 44) { if (!this.BrowserChrome.Check())//仍然支持npapi { _this.chrome45 = true;// _this.Browser = this.BrowserNat; _this.Browser.Check(); this.WordParser = this.WordParserNat; } } } this.setupTip = function () { this.OpenDialogPaste(); var dom = this.imgMsg.html("未检测到控件,请先安装控件,Chrome 45+需要单独安装扩展"); var lnk = dom.find('a[name="aCtl"]'); lnk.attr("href", this.Config["ExePath"]); var crx = dom.find('a[name="aCrx"]'); crx.attr("href", this.Config["NatPath"]); this.imgPercent.hide(); this.imgIco.hide(); }; this.CheckUpdate = function () { if (this.Browser.CheckVer()) { this.OpenDialogPaste(); var dom = this.imgMsg.html("控件有新版本,请更新控件"); var lnk = dom.find('a[name="aCtl"]'); lnk.attr("href", this.Config["ExePath"]); this.imgPercent.hide(); this.imgIco.hide(); } }; //加载控件及HTML元素 this.GetHtml = function () { //Word图片粘贴 var acx = ""; /* 静态加截控件代码,在复杂WEB系统中或者框架页面中请静态方式加截Word解析组件(Xproer.WordParser)。 */ if(!this.chrome45) acx += ''; //Word解析组件 acx += ' 图片上传中...10%'; acx += ''; //图片批量上传窗口 acx += ''; // acx += '
'; //文件上传列表项模板 acx += '
\
\
HttpUploader程序开发.pdf
\
\
\
\
已上传:15.3MB 速度:20KB/S 剩余时间:10:02:00
\
\
\ 取消\
35%
\
'; acx += '
'; //template end //分隔线 acx += '
'; //hide div end acx += '
'; return acx; }; //加载控件及HTML元素 this.Load = function () { var dom = $(document.body).append(this.GetHtml()); this.ffPaster = dom.find('embed[name="ffPaster"]').get(0); this.ieParser = dom.find('object[name="ieParser"]').get(0); this.line = dom.find('div[name="line"]'); this.fileItem = dom.find('div[name="fileItem"]'); this.filesPanel = dom.find('div[name="filesPanel"]'); this.imgUploaderDlg = dom.find('div[name="filesPanel"]'); this.imgPasterDlg = dom.find('div[name="imgPasterDlg"]'); this.imgIco = this.imgPasterDlg.find('img[name="ico"]'); this.imgMsg = this.imgPasterDlg.find('span[name="msg"]'); this.imgPercent = this.imgPasterDlg.find('span[name="percent"]'); this.init(); }; this.LoadTo = function (oid) { var dom = $("#" + oid).append(this.GetHtml()); this.ffPaster = dom.find('embed[name="ffPaster"]').get(0); this.ieParser = dom.find('object[name="ieParser"]').get(0); this.line = dom.find('div[name="line"]'); this.fileItem = dom.find('div[name="fileItem"]'); this.filesPanel = dom.find('div[name="filesPanel"]'); this.imgUploaderDlg = dom.find('div[name="filesPanel"]'); this.imgPasterDlg = dom.find('div[name="imgPasterDlg"]'); this.imgIco = this.imgPasterDlg.find('img[name="ico"]'); this.imgMsg = this.imgPasterDlg.find('span[name="msg"]'); this.imgPercent = this.imgPasterDlg.find('span[name="percent"]'); this.init(); }; //在文档加载完毕后调用 this.init = function () { $(function () { _this.setuped = _this.Browser.Check(); if (_this.setuped) { _this.WordParser.Init();// _this.CheckUpdate();// } else { _this.setupTip(); } }); }; //打开图片上传对话框 this.OpenDialogFile = function () { _this.imgUploaderDlg.skygqbox(); }; this.CloseDialogFile = function () { $('#wrapClose').click(); }; //打开粘贴图片对话框 this.OpenDialogPaste = function () { _this.imgPasterDlg.skygqbox(); }; this.CloseDialogPaste = function () { $('#wrapClose').click(); }; this.InsertHtml = function (html) { _this.Editor.appendHTML(html); }; this.GetEditor = function () { return this.Editor; }; //在FCKeditor_OnComplete()中调用 this.SetEditor = function (edt) { _this.Editor = edt; //_this.WordPaster.Editor = edt; //_this.ImagePaster.Editor = edt; }; //点击按钮进行粘贴 this.Paste = function () { if (!this.setuped) { this.setupTip(); return; }//chrome 45直接调用控件命令 if (this.chrome45) { if (!this.natInstalled) { this.setupTip(); return;} _this.WordParser.Paste(); }//非chrome 45则进行判断 else { if (_this.WordParser.HasData()) _this.WordParser.Paste(); else { return true; } return false; } }; //上传网络图片 this.UploadNetImg = function () { var data = _this.Editor.getSource(); _this.WordParser.PasteAuto(data); }; //加载粘贴事件 this.LoadPasteEvent = function (edt) { edt.on('paste', function (evt) { _this.Paste(evt); }); }; /* 验证文件名是否存在 参数: fileName 包含完整路径的文件名称 */ this.Exist = function(fileName) { for (a in this.UploaderList) { if (this.UploaderList[a].LocalFile == fileName) { return true; } } return false; }; /* 根据ID删除上传任务 参数: fileID */ this.Delete = function(fileID) { var obj = this.UploaderList[fileID]; if (null == obj) return; var tbID = "item" + obj.FileID; var item = document.getElementById(tbID); if (item) document.removeChild(item); //删除 }; /* 添加到上传列表 参数 index 上传对象唯一标识 uploaderObj 上传对象 */ this.AppendToUploaderList = function(index, uploaderObj) { this.UploaderList[index] = uploaderObj; ++this.UploaderListCount; }; /* 添加到上传列表层 参数 fid 文件ID div 上传信息层对象 obj 上传对象 */ this.AppendToListDiv = function(fid, div, obj) { var line = this.line.clone(true); //分隔线 line.attr("id", "FilePostLine" + fid) .css("display", "block"); obj.Separator = line; this.filesPanel.append(div); this.filesPanel.append(line); }; /* 更新编辑器内容。 在所有图片上传完后调用。 在上传图片出现错误时调用。 */ this.UpdateContent = function () { _this.InsertHtml(_this.EditorContent); }; this.addImgLoc = function (img) { var fid = img.id; var task = new FileUploader(img.id, img.src, this, img.width, img.height); this.fileMap[img.id] = task;//添加到文件映射表 var ui = this.fileItem.clone(); ui.css("display", "block").attr("id", "item" + fid); var objFileName = ui.find('div[name="fname"]'); var divMsg = ui.find('div[name="msg"]'); var aBtn = ui.find('a[name="btn"]'); var divPercent = ui.find('div[name="percent"]'); var divProcess = ui.find('div[name="process"]'); objFileName.text(img.name).attr("title", img.name); task.pProcess = divProcess; task.pMsg = divMsg; task.pMsg.text(""); task.pButton = aBtn; aBtn.attr("fid", fid) .attr("domid", "item" + fid) .attr("lineid", "FilePostLine" + fid) .click(function () { switch ($(this).text()) { case "暂停": case "停止": upFile.Stop(); break; case "取消": { upFile.Remove(); } break; case "续传": case "重试": upFile.Post(); break; } }); task.pPercent = divPercent; task.pPercent.text("0%"); task.ImageTag = img.html; //图片标记 task.InfDiv = ui;//上传信息DIV //添加到上传列表层 this.AppendToListDiv(fid, ui, task); //添加到上传列表 this.AppendToUploaderList(fid, task); task.Ready(); //准备 return task; }; this.WordParser_PasteWord = function (json) { this.postType = WordPasteImgType.word; this.EditorContent = json.word; for (var i = 0, l = json.imgs.length; i < l; ++i) { this.addImgLoc(json.imgs[i]); } this.OpenDialogFile(); }; this.WordParser_PasteExcel = function (json) { this.postType = WordPasteImgType.word; this.EditorContent = json.word; for (var i = 0, l = json.imgs.length; i < l; ++i) { this.addImgLoc(json.imgs[i]); } this.OpenDialogFile(); }; this.WordParser_PasteHtml = function (json) { this.postType = WordPasteImgType.word; this.InsertHtml(json.word);// this.working = false; }; this.WordParser_PasteFiles = function (json) { this.postType = WordPasteImgType.local; for (var i = 0, l = json.imgs.length; i < l; ++i) { var task = this.addImgLoc(json.imgs[i]); task.PostLocalFile = true;// } this.OpenDialogFile(); }; this.WordParser_PasteImage = function (json) { this.OpenDialogPaste(); this.imgMsg.text("开始上传"); this.imgPercent.text("1%"); }; this.WordParser_PasteAuto = function (json) { this.postType = WordPasteImgType.network; for (var i = 0, l = json.imgs.length; i < l; ++i) { this.addImgLoc(json.imgs[i]); } this.OpenDialogFile(); }; this.WordParser_PostComplete = function (json) { this.event.postComplete(json.value); this.imgPercent.text("100%"); this.imgMsg.text("上传完成"); var img = ""; this.InsertHtml(img); this.CloseDialogPaste(); this.working = false; }; this.WordParser_PostProcess = function (json) { this.imgPercent.text(json.percent); }; this.WordParser_PostError = function (json) { this.OpenDialogPaste(); this.imgMsg.text(WordPasterError[json.value]); this.imgIco.src = this.Config["IcoError"]; this.imgPercent.text(""); }; this.File_PostComplete = function (json) { this.event.postComplete(json.pathSvr); var up = this.fileMap[json.id]; up.postComplete(json); delete up;// }; this.File_PostProcess = function (json) { var up = this.fileMap[json.id]; up.postProcess(json); }; this.File_PostError = function (json) { var up = this.fileMap[json.id]; up.postError(json); }; this.Queue_Complete = function (json) { //上传网络图片 if (_this.postType == WordPasteImgType.network) { _this.GetEditor().setSource(json.word); } //上传Word图片时才替换内容 else if (_this.postType == WordPasteImgType.word) { _this.InsertHtml(json.word);// } this.CloseDialogFile(); _this.working = false; this.event.queueComplete(); }; this.WordParser_StateChanged = function (msg) { var json = JSON.parse(msg); if (json.name == "Parser_PasteWord") _this.WordParser_PasteWord(json); else if (json.name == "Parser_PasteExcel") _this.WordParser_PasteExcel(json); else if (json.name == "Parser_PasteHtml") _this.WordParser_PasteHtml(json); else if (json.name == "Parser_PasteFiles") _this.WordParser_PasteFiles(json); else if (json.name == "Parser_PasteImage") _this.WordParser_PasteImage(json); else if (json.name == "Parser_PasteAuto") _this.WordParser_PasteAuto(json); else if (json.name == "Parser_PostComplete") _this.WordParser_PostComplete(json); else if (json.name == "Parser_PostProcess") _this.WordParser_PostProcess(json); else if (json.name == "Parser_PostError") _this.WordParser_PostError(json); else if (json.name == "File_PostProcess") _this.File_PostProcess(json); else if (json.name == "File_PostComplete") _this.File_PostComplete(json); else if (json.name == "File_PostError") _this.File_PostError(json); else if (json.name == "Queue_Complete") _this.Queue_Complete(json); }; } var FileUploaderState = { Ready: 0, Posting: 1, Stop: 2, Error: 3, GetNewID: 4, Complete: 5, WaitContinueUpload: 6, None: 7, Waiting: 8 }; /* 文件上传对象 参数: fileID 文件唯一标识 filePath 包含完整路径的本地文件名称。D:\Soft\QQ.exe width 图片宽度 height 图片高度 属性: pMsg 显示上传信息,进度信息 pProcess 进度条 pPercent 显示百分比文字 pButton 按钮按钮 LocalFile 本地文件路径。D:\Soft\QQ.exe ImageTag 图片标记。 InfDiv 上传信息层。 Separator 分隔线 */ function FileUploader(fileID,filePath,mgr,width,height) { var _this = this; this.Manager = mgr; this.Editor = mgr.Editor; this.Config = mgr.Config; this.ActiveX = mgr.ActiveX; this.Fields = mgr.Fields; this.Browser = mgr.Browser; this.InsertHtml = mgr.InsertHtml; this.PostLocalFile = false;//是否上传本地文件 this.imgW = width; this.imgH = height; this.LocaFile = filePath;//网络图片需要使用 this.State = FileUploaderState.None; this.LocalFile = filePath; this.FileID = fileID; this.idLoc = fileID;//add(2015-12-10) this.ImageTag = ""; //图片标记,在图片上传完后需要替换此标记 this.postComplete = function (json) { this.pButton.text(""); this.pProcess.css("width", "100%"); this.pPercent.text("100%"); this.pMsg.text("上传完成"); //从上传列表中清除 this.Remove(); //更新编辑器中的图片标签 this.FilePostComplete(json.pathSvr); }; this.postError = function (json) { this.pMsg.text(WordPasterError[json.value]); this.pButton.text("重试"); }; this.postProcess = function (json) { var msg = "已上传:" + json.len + " 速度:" + json.speed + " 剩余时间:" + json.time; this.pMsg.text(msg); this.pPercent.text(json.percent); this.pProcess.css("width", json.percent); }; //方法-准备 this.Ready = function() { //this.pButton.style.display = "none"; _this.pMsg.text("正在上传队列中等待..."); _this.State = FileUploaderState.Ready; }; //从上传列表中删除 this.Remove = function() { //删除信息层 _this.InfDiv.remove(); //删除分隔线 _this.Separator.remove(); //清空本地文件名称 _this.LocalFile = ""; }; //停止传输 this.Stop = function() { //var obj = _this.Manager.UploaderList[fid]; this.ATL.Stop(); this.State = FileUploaderState.Stop; this.pButton.text("重试"); }; //本地图片文件上传完毕 this.LocalFileComplete = function (imgSrc) { var img = ''; _this.InsertHtml(img); }; //文件上传完毕 this.FilePostComplete = function(imgSrc) { //上传的本地文件 if (_this.PostLocalFile) { _this.LocalFileComplete(imgSrc); } }; }

 

你可能感兴趣的:(asp.net,在线富文本编辑器)