富文本之BootStrap-wysiwyg 帶圖片上傳功能


BootStrap-wysiwyg插件具備良好的編輯功能和展現效果。
1、使用方法在網上有不少,在此記錄本身使用過程當中的一些問題和解決方式。css

相關依賴:html

bootstrap-wysiwyg.js (核心)
jquery.hotkeys.js (快捷鍵)
prettify.js jquery

prettify.css
edit.css (頁面展現效果,可自定義)web

bootstrap.min.css
font-awesome.css (字體圖片樣式)bootstrap

bootstrap.min.js
jquery2.1.4.min.js

相關文件地址:【相關文件下載地址】promise

頁面代碼:服務器

//工具欄的定義 <div class="btn-toolbar" data-role="editor-toolbar" data-target="#editor">
<div class="btn-group">
<a class="btn dropdown-toggle" data-toggle="dropdown" title="Font"><i class="icon-font"></i><b class="caret"></b></a>
<ul class="dropdown-menu">
</ul>
</div>
<div class="btn-group">
<a class="btn dropdown-toggle" data-toggle="dropdown" title="Font Size"><i class="icon-text-height"></i>&nbsp;<b class="caret"></b></a>
<ul class="dropdown-menu">
<li><a data-edit="fontSize 5"><font size="5">Huge</font></a></li>
<li><a data-edit="fontSize 3"><font size="3">Normal</font></a></li>
<li><a data-edit="fontSize 1"><font size="1">Small</font></a></li>
</ul>
</div>
<div class="btn-group">
<a class="btn" data-edit="bold" title="Bold (Ctrl/Cmd+B)"><i class="icon-bold"></i></a>
<a class="btn" data-edit="italic" title="Italic (Ctrl/Cmd+I)"><i class="icon-italic"></i></a>
<a class="btn" data-edit="strikethrough" title="Strikethrough"><i class="icon-strikethrough"></i></a>
<a class="btn" data-edit="underline" title="Underline (Ctrl/Cmd+U)"><i class="icon-underline"></i></a>
</div>
<div class="btn-group">
<a class="btn" data-edit="insertunorderedlist" title="Bullet list"><i class="icon-list-ul"></i></a>
<a class="btn" data-edit="insertorderedlist" title="Number list"><i class="icon-list-ol"></i></a>
<a class="btn" data-edit="outdent" title="Reduce indent (Shift+Tab)"><i class="icon-indent-left"></i></a>
<a class="btn" data-edit="indent" title="Indent (Tab)"><i class="icon-indent-right"></i></a>
</div>
<div class="btn-group">
<a class="btn" data-edit="justifyleft" title="Align Left (Ctrl/Cmd+L)"><i class="icon-align-left"></i></a>
<a class="btn" data-edit="justifycenter" title="Center (Ctrl/Cmd+E)"><i class="icon-align-center"></i></a>
<a class="btn" data-edit="justifyright" title="Align Right (Ctrl/Cmd+R)"><i class="icon-align-right"></i></a>
<a class="btn" data-edit="justifyfull" title="Justify (Ctrl/Cmd+J)"><i class="icon-align-justify"></i></a>
</div>
<div class="btn-group">
<a class="btn dropdown-toggle" data-toggle="dropdown" title="Hyperlink"><i class="icon-link"></i></a>
<div class="dropdown-menu input-append">
<input class="span2" placeholder="URL" type="text" data-edit="createLink"/>
<button class="btn" type="button">Add</button>
</div>
<a class="btn" data-edit="unlink" title="Remove Hyperlink"><i class="icon-cut"></i></a>
</div>

<div class="btn-group">
<a class="btn" title="Insert picture (or just drag & drop)" id="pictureBtn"><i class="icon-picture"></i></a>
<input type="file" data-role="magic-overlay" data-target="#pictureBtn" data-edit="insertImage" />
</div>
<div class="btn-group">
<a class="btn" data-edit="undo" title="Undo (Ctrl/Cmd+Z)"><i class="icon-undo"></i></a>
<a class="btn" data-edit="redo" title="Redo (Ctrl/Cmd+Y)"><i class="icon-repeat"></i></a>
</div>
<input type="text" data-edit="inserttext" id="voiceBtn" x-webkit-speech="">
</div> //文本輸入區域 <div id="editor"> 輸入內容&hellip;
</div>

 

JS代碼:app

//初始化工具欄ide

 1 function initToolbarBootstrapBindings() {  2 var fonts = ['Serif', 'Sans', 'Arial', 'Arial Black', 'Courier',  3 'Courier New', 'Comic Sans MS', 'Helvetica', 'Impact', 'Lucida Grande', 'Lucida Sans', 'Tahoma', 'Times',  4 'Times New Roman', 'Verdana'],  5 fontTarget = $('[title=Font]').siblings('.dropdown-menu');  6 $.each(fonts, function (idx, fontName) {  7 fontTarget.append($('<li><a data-edit="fontName ' + fontName +'" style="font-family:\''+ fontName +'\'">'+fontName + '</a></li>'));  8 });  9 $('a[title]').tooltip({container:'body'}); 10 $('.dropdown-menu input').click(function() {return false;}) 11 .change(function () {$(this).parent('.dropdown-menu').siblings('.dropdown-toggle').dropdown('toggle');}) 12 .keydown('esc', function () {this.value='';$(this).change();}); 13 
14 $('[data-role=magic-overlay]').each(function () { 15 var overlay = $(this), target = $(overlay.data('target')); 16 overlay.css('opacity', 0).css('position', 'absolute').offset(target.offset()).width(target.outerWidth()).height(target.outerHeight()); 17 }); 18 if ("onwebkitspeechchange" in document.createElement("input")) { 19 var editorOffset = $('#editor').offset(); 20 $('#voiceBtn').css('position','absolute').offset({top: editorOffset.top, left: editorOffset.left+$('#editor').innerWidth()-35}); 21 } else { 22 $('#voiceBtn').hide(); 23 } 24 }; 25 //錯誤提示
26 function showErrorAlert (reason, detail) { 27 var msg=''; 28 if (reason==='unsupported-file-type') { msg = "Unsupported format " +detail; } 29 else { 30 console.log("error uploading file", reason, detail); 31 } 32 $('<div class="alert"> <button type="button" class="close" data-dismiss="alert">&times;</button>'+ 
33 '<strong>File upload error</strong> '+msg+' </div>').prependTo('#alerts'); 34 }; 35 initToolbarBootstrapBindings(); 36 $('#editor').wysiwyg({ fileUploadError: showErrorAlert} );

 

2、自定義上傳圖片到服務器
主要修改bootstrap-wysiwyg.js中的一個方法工具

 1 var readFileIntoDataUrl = function (fileInfo) {  2 //原有的方法
 3 // var loader = $.Deferred(),
 4 // fReader = new FileReader();
 5 // fReader.onload = function (e) {
 6 // loader.resolve(e.target.result);
 7 // };
 8 // fReader.onerror = loader.reject;
 9 // fReader.onprogress = loader.notify;
10 // fReader.readAsDataURL(fileInfo);
11 // return loader.promise();
12 
13 //自定義方法
14 var form = new FormData(); 15 form.append("file", fileInfo); 16 var xhr = new XMLHttpRequest(); 17 xhr.open("post", "/imgupload", false);//後臺接收的方法,返回圖片路徑(全路徑,否則頁面不顯示圖片)
18 xhr.send(form); 19 return xhr.responseText; 20 };

 

後臺接收的方法示例:

 1  public string UpLoadImgFile()  2  {  3             string szNewFilePath = "";  4             if (Request.Files.Count>0)  5  {  6                 HttpPostedFileBase CoverImg = Request.Files[0];  7                 Stream sr = CoverImg.InputStream;  8                 FileRepositoryServiceClient client = new FileRepositoryServiceClient("http://uploadfile.qikan.com.cn/FileRepositoryService.svc", "MediaFile", "MediaFile");  9                 
10                 client.CreateImageFile("MediaFile/" + Request.Files[0].FileName, sr, out szNewFilePath); 11                
12  } 13             return szNewFilePath = DragonUtility.IO.FileService.Client.FileRepositoryServiceClient.GetFilePath("Public/MediaFile", szNewFilePath); 14             //return RetActionJsonResult(SetSuccessResult(szNewFilePath));
15         }

 


3、傳遞參數

//在回臺接收輸入區域的內容使用jQuery$("#editor").html();結束: 這只是簡單的使用示例。 還有不少更方便的使用技巧,但願有經驗的朋友留言,共同窗習。

相關文章
相關標籤/搜索