使用富文本編輯器(官網)時,大多時候都會用到圖片上傳,可是下載的富文本編輯器的默認配置是隻有一個上傳地址的host的。html
var he = HE.getEditor('editor', { autoHeight: true, autoFloat: false, topOffset: 0, uploadPhoto: true, uploadPhotoUrl: uploadDomain, uploadPhotoHandler: "", uploadPhotoSize: 200, uploadPhotoType: 'gif,png,jpg,jpeg', uploadPhotoSizeError: '不能上傳大於2MB的圖片', uploadPhotoTypeError: '只能上傳gif,png,jpg,jpeg格式的圖片', lang: 'zh-jian', skin: 'HandyEditor', externalSkin: '', item: ['bold', 'italic', 'strike', 'underline', 'fontSize', 'fontName', 'paragraph', 'color', 'backColor', '|', 'center', 'left', 'right', 'full', 'indent', 'outdent', '|', 'link', 'unlink', 'textBlock', 'code', 'selectAll', 'removeFormat', 'trash', '|', 'image', 'expression', 'subscript', 'superscript', 'horizontal', 'orderedList', 'unorderedList', '|', 'undo', 'redo', '|', 'html', '|', 'about'] });
var content = he.getHtml() 得到html代碼 具體配置可參考官網:http://he.catfish-cms.com/#jibenshiyong。面試
可是,此項目使用的是阿里雲的oss服務,而後上傳圖片(使用了一個本身的中間服務)和預覽圖片使用了兩個host地址。這個時候使用默認的配置,就會出現上傳圖片成功,可是編輯器圖片卻沒法正常預覽,以下圖所示:express
但其實圖片是上傳成功了:編輯器
這個時候,咱們使用正常的預覽host加上此路徑,是能夠正常預覽的,編輯器中顯示錯誤是由於host地址是上傳的host,因此顯示不了,同時致使生成的代碼裏邊的img的src也是錯誤的。阿里雲
解決思路:再配置一個預覽地址,上傳成功後,用預覽地址的host代替上傳的host拼接路徑,而後正常打開,這樣getHtml中的圖片地址也就能夠正常打開了。spa
按照這個思路,看了下他的源碼HandyEditor,準備修改他的HE構造器,添加一個預覽的host地址3d
修改預覽地址(以前是 uploadPhotoUrl):code
這樣就能夠在配置時多加一個構造參數,而後加載頁面試試看,正常上傳而且能夠正常預覽了。orm
正常預覽(生成的代碼也對):htm
成功。