wangEditor-基於javascript和css開發的 Web富文本編輯器, 輕量、簡潔、易用、開源免費(2)

来源:https://www.cnblogs.com/lprosper/archive/2018/08/18/9498867.html
-Advertisement-
Play Games

1 2 3 4 5 6 wangEditor上傳圖片到伺服器 7 8 9 10 11 12 13 14 15 16 119 120 121 ...


  1 <!DOCTYPE html>
  2 <html lang="en">
  3 
  4 <head>
  5     <meta charset="UTF-8">
  6     <title>wangEditor上傳圖片到伺服器</title>
  7 </head>
  8 
  9 <body>
 10 
 11     <div id="editor"></div>
 12 
 13     <!-- 註意, 只需要引用 JS,無需引用任何 CSS !!!-->
 14     <script src="http://code.jquery.com/jquery-1.11.3.min.js"></script>
 15     <script type="text/javascript" src="script/wangEditor-3.1.1.js"></script>
 16     <script type="text/javascript">
 17     // 聲明富文本編輯器
 18     var E = window.wangEditor;
 19 
 20     // 初始化富文本編輯器
 21     var editor = new E('#editor');
 22 
 23     // 上傳圖片到伺服器
 24     editor.customConfig.uploadImgServer = '/upload'; // 其中/upload是上傳圖片的伺服器端介面
 25 
 26     // 將圖片大小限製為 3M
 27     editor.customConfig.uploadImgMaxSize = 3 * 1024 * 1024;
 28 
 29     // 預設為 10000 張(即不限制),需要限制可自己配置
 30     // 限制一次最多上傳 5 張圖片
 31     editor.customConfig.uploadImgMaxLength = 5;
 32 
 33     // 上傳圖片時可自定義傳遞一些參數,例如傳遞驗證的token等。參數會被添加到formdata中
 34     editor.customConfig.uploadImgParams = {
 35         // 如果版本 <=v3.1.0 ,屬性值會自動進行 encode ,此處無需 encode
 36         // 如果版本 >=v3.1.1 ,屬性值不會自動 encode ,如有需要自己手動 encode
 37         token: 'abcdef12345'
 38     }
 39 
 40     // 如果還需要將參數拼接到 url 中,可再加上如下配置
 41     editor.customConfig.uploadImgParamsWithUrl = true;
 42 
 43     // 上傳圖片時,可自定義filename,即在使用formdata.append(name, file)添加圖片文件時,自定義第一個參數。
 44     editor.customConfig.uploadFileName = 'yourFileName';
 45 
 46     // 上傳圖片時刻自定義設置 header
 47     editor.customConfig.uploadImgHeaders = {
 48         'Accept': 'text/x-json'
 49     }
 50 
 51     // 跨域上傳中如果需要傳遞 cookie 需設置 withCredentials
 52     editor.customConfig.withCredentials = true;
 53 
 54     // 預設的 timeout 時間是 10 秒鐘
 55     // 將 timeout 時間改為 3s
 56     editor.customConfig.uploadImgTimeout = 3000;
 57 
 58     // 上傳圖片的錯誤提示預設使用alert彈出,你也可以自定義用戶體驗更好的提示方式
 59     editor.customConfig.customAlert = function(info) {
 60         // info 是需要提示的內容
 61         alert('自定義提示:' + info);
 62     }
 63 
 64     // 可使用監聽函數在上傳圖片的不同階段做相應處理
 65     editor.customConfig.uploadImgHooks = {
 66         before: function(xhr, editor, files) {
 67             // 圖片上傳之前觸發
 68             // xhr 是 XMLHttpRequst 對象,editor 是編輯器對象,files 是選擇的圖片文件
 69 
 70             // 如果返回的結果是 {prevent: true, msg: 'xxxx'} 則表示用戶放棄上傳
 71             // return {
 72             //     prevent: true,
 73             //     msg: '放棄上傳'
 74             // }
 75         },
 76         success: function(xhr, editor, result) {
 77             // 圖片上傳並返回結果,圖片插入成功之後觸發
 78             // xhr 是 XMLHttpRequst 對象,editor 是編輯器對象,result 是伺服器端返回的結果
 79         },
 80         fail: function(xhr, editor, result) {
 81             // 圖片上傳並返回結果,但圖片插入錯誤時觸發
 82             // xhr 是 XMLHttpRequst 對象,editor 是編輯器對象,result 是伺服器端返回的結果
 83         },
 84         error: function(xhr, editor) {
 85             // 圖片上傳出錯時觸發
 86             // xhr 是 XMLHttpRequst 對象,editor 是編輯器對象
 87         },
 88         timeout: function(xhr, editor) {
 89             // 圖片上傳超時時觸發
 90             // xhr 是 XMLHttpRequst 對象,editor 是編輯器對象
 91         },
 92 
 93         // 如果伺服器端返回的不是 {errno:0, data: [...]} 這種格式,可使用該配置
 94         // (但是,伺服器端返回的必須是一個 JSON 格式字元串!!!否則會報錯)
 95         customInsert: function(insertImg, result, editor) {
 96             // 圖片上傳並返回結果,自定義插入圖片的事件(而不是編輯器自動插入圖片!!!)
 97             // insertImg 是插入圖片的函數,editor 是編輯器對象,result 是伺服器端返回的結果
 98 
 99             // 舉例:假如上傳圖片成功後,伺服器端返回的是 {url:'....'} 這種格式,即可這樣插入圖片:
100             var url = result.url
101             insertImg(url)
102 
103             // result 必須是一個 JSON 格式字元串!!!否則報錯
104         }
105     }
106 
107     // 如果想完全自己控製圖片上傳的過程,可以使用如下代碼
108     editor.customConfig.customUploadImg = function(files, insert) {
109         // files 是 input 中選中的文件列表
110         // insert 是獲取圖片 url 後,插入到編輯器的方法
111 
112         // 上傳代碼返回結果之後,將圖片插入到編輯器中
113         insert(imgUrl)
114     }
115 
116     // 創建編輯器1
117     editor.create();
118     </script>
119 </body>
120 
121 </html>

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Hadoop發展到今天家族產品已經非常豐富,能夠滿足不同場景的大數據處理需求。作為目前主流的大數據處理技術,市場上很多公司的大數據業務都是基於Hadoop開展,而且對很多場景已經具有非常成熟的解決方案。 作為開發人員掌握Hadoop及其生態內框架的開發技術,就是進入大數據領域的必經之路。 下麵詳細介 ...
  • 總結一下近期學習的大數據知識, 學習之前沒搞清楚的知識 傳統的web應用(LAMP、JavaEE、NODE系等)與大數據什麼關係? 之前一直以為大數據的東西就是來取代傳統的Web應用的,其實並不是這樣;即使是大數據的架構,應用層依然會是傳統的web應用,但是會根據數據特點對數據存儲(結構化數據依然會 ...
  • 註:此文章所寫內容完全在虛擬機配置,系統:centos,jdk和hadoop已經安裝完成所配集群包括hadoop01,hadoop02,hadoop03,hadoop04四台,ip分別為:192.168.80.101,192.168.80.102,192.168.80.103,192.168.80. ...
  • redis五大數據類型:string(字元串),hash(哈希,類似java的Map),list(列表),set(集合),zset(有序集合) 1、redis的鍵(key) keys 查詢資料庫中的key值,keys * 查出所有,keys rt* 查出匹配的key exists key 判斷key ...
  • weight詳解 是用來等比例劃分區域的屬性。 案例代碼 為什麼出現2:1的案例呢?three怎麼就不見了呢? 1. 每個寬度為 ,屏幕為1,那麼屏幕就是1 3= 2個 2. 計算方法, ,結果是one占了兩份,two占了一份,three什麼都沒有 ,`padding`詳解 代表是偏移,表示組件離容 ...
  • UI的描述 對於 應用程式中,所有用戶界面元素都是由 和`ViewGroup View ViewGroup View ViewGroup`對象的佈局容器! 為我們提供了 和`ViewGroup`的兩個子類的集合,提供常用的一些輸入控制項(比如按鈕,圖片和文本域等)和各種各樣的佈局模式(比如線程佈局,相 ...
  • 前言 lodash受歡迎的一個原因,是其優異的計算性能。而其性能能有這麼突出的表現,很大部分就來源於其使用的演算法——惰性求值。 本文將講述lodash源碼中,惰性求值的原理和實現。 一、惰性求值的原理分析 惰性求值(Lazy Evaluation),又譯為惰性計算、懶惰求值,也稱為傳需求調用(cal ...
  • 五層網路模型 簡介 互聯網的實現,依托於網路協議。網路協議又分為好幾層,關於如何分層有過很多爭論,比較受人認可的有五層模型、七層模型、四層模型。今天我們就來講講五層網路模型。 從名字就可以看出來,五層網路模型將網路協議分為五層,每層都有對應的一些網路協議。從上到下分別是: 應用層 傳輸層 網路層 數 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...