解決summernote打開本地文件夾慢的問題

開發項目時,遇到summernote,打開本地文件夾時,非常的慢,以下是解決辦法:

找到summernote.min.js

accept="image/*"

替換為:

accept="image/jpg,image/jpeg,image/webp,image/png,image/svg,image/gif"
修改位置部分

如果不行,請清除一下瀏覽器緩存

以下是實際開發效果圖

項目效果圖

----------------------------------------------我是分割線------------------------------------------

附summernote+springboot整合代碼:
html需要引入(這個就自己下載喏)

    <link href="../../css/plugins/summernote/summernote.css" rel="stylesheet" />
    <link href="../../css/plugins/summernote/summernote-bs3.css" rel="stylesheet" />
    <script src="../../js/plugins/summernote/summernote.min.js" type="text/javascript"></script>
    <script src="../../js/plugins/summernote/summernote-zh-CN.js" type="text/javascript"></script>

內容區(我相信css樣式難不倒聰明的你)

<div class="wrapper wrapper-content">
    <div class="row">
        <div class="col-sm-12" style="width:550px">
            <div class="ibox float-e-margins">
                <div class="ibox-title">
                    <h1>公司簡介</h1>
                    <button id="cancel" class="btn btn-warning btn-xs m-l-sm" onclick="cancelEdit()" type="button">放棄本次編輯</button>
                    <button id="edit" class="btn btn-primary btn-xs" onclick="profileEdit()" type="button">編輯</button>
                    <button id="save" class="btn btn-primary  btn-xs" onclick="profileSave()" type="button">保存</button>
                </div>
                <div class="ibox-content no-padding" id="eg">
                    <div id="summernote">
                        <h3>親愛的用戶,您好:</h3>
                        <br/>
                        <p>&nbsp;&nbsp;&nbsp;&nbsp;開始編輯您的內容吧.</p>
                        <br/>
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>

相關js函數(提示彈出框用的是 sweetAlert,自行百度)

$(document).ready(function() {
    $('#summernote').summernote({
        lang: 'zh-CN', // default: 'en-US'
        focus:true,
        onImageUpload: function(files, editor, welEditable) {
            sendFile(files[0],editor,welEditable);
        }
    });
});

function sendFile(file, editor, welEditable){
    var filename = false;
    try {
        filename = file['name'];
    } catch (e) {
        filename = false;
    }
    if (!filename) {
        $(".note-alarm").remove();
    }
    //以上防止在圖片在編輯器內拖拽引發第二次上傳導致的提示錯誤
    var ext = filename.substr(filename.lastIndexOf("."));
    ext = ext.toUpperCase();
    var timestamp = new Date().getTime();
    var name = timestamp+"_"+$("#summernote").attr('aid')+ext;
    //name是文件名,自己隨意定義,aid是我自己增加的屬性用于區分文件用戶
    data = new FormData();
    data.append("file", file);

    $.ajax({
        data: data,
        type: "POST",
        url: "/logistics/common/picSave", //圖片上傳出來的url,返回的是圖片上傳后的路徑,http格式
        cache: false,
        contentType: false,
        processData: false,
        success: function(url) {
            //data是返回的hash,key之類的值,key是定義的文件名,把圖片放到編輯框中
            editor.insertImage(welEditable, url);
//            $('#summernote').summernote('insertImage', url); //這種方式有問題
        },
        error: function(){
            swal({
                type:"warning",
                title:"",
                text: "上傳失敗",
                confirmButtonText: '知道的啦'
            });
        }
    });
}

//編輯, 初始化組件, 加上圖片上傳初始化
function profileEdit(){
    $("#eg").addClass("no-padding");
    $('#summernote').summernote({
        lang: 'zh-CN', // default: 'en-US'
        focus:true,
        onImageUpload: function(files, editor, welEditable) {
            sendFile(files[0],editor,welEditable);
        }
    });
}

//保存, 銷毀組件
function profileSave(){
    data = new FormData();
    $("#eg").removeClass("no-padding");
    var aHTML = $('#summernote').code();//獲取內容
    data.append("content", aHTML);
    $('#summernote').destroy(); //銷毀
    $.ajax({
        data: data,
        type: "POST",
        url: "/company/picSave", //圖片上傳出來的url,返回的是圖片上傳后的路徑,http格式
        cache: false,
        contentType: false,
        processData: false,
        success: function(res) {
            if (res.code === "0"){
                swal({
                    type:"success",
                    title:"",
                    text: res.msg,
                    confirmButtonText: '那必須的'
                });
            } else {
                swal({
                    type:"warning",
                    title:"",
                    text: "啊哦,保存失敗",
                    confirmButtonText: '朕知道了'
                });
            }

        }
    });
}

//取消, 銷毀組件
function cancelEdit(){
    $("#eg").removeClass("no-padding");
    $('#summernote').destroy(); //銷毀
    self.location.reload(); //取消時重新刷新界面
}

springboot后臺參考代碼(如果有需要對圖片進行壓縮或者加水印需求的同學請自行百度哦):
類上的注釋使用:@RestController

 /**
     * @param file
     * @return
     * @throws IOException
     */
    @RequestMapping(value = "/common/picSave", produces = "text/html;charset=UTF-8", method = RequestMethod.POST)
    @ResponseBody
    public String commonPicSave(@RequestParam("file") MultipartFile file) throws IOException {
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy_MM");
        String file_name = sdf.format(new Date());
        String fileName;
        String suffixName;
        OutputStream out = null;
        InputStream in = null;
        String _path = "";
        String path = "c:\\myPath"+ file_name + "/";
        if (!file.isEmpty()) {
            fileName = file.getOriginalFilename();
            suffixName = fileName.substring(fileName.lastIndexOf("."));
            fileName = UUID.randomUUID() + "_" + new Random().nextInt(10000) + suffixName; //重新命名
            // 檢測是否存在目錄
            String filePath = path + fileName;
            File dest = new File(filePath);
            if (!dest.getParentFile().exists()) {
                dest.getParentFile().mkdirs();
            }
            out = new FileOutputStream(new File(path, fileName));
            in = file.getInputStream();
            int length;
            byte[] buf = new byte[1024];
            while ((length = in.read(buf)) != -1) {
                out.write(buf, 0, length);
            }
            in.close();
            out.close();
            _path = type + "/" + file_name + "/" + fileName;
            ShiroUtils.setSessionAttribute(type, "/" + _path); // 將圖片放到session中
            System.out.println("/" + _path);
        }
        return baseUrl + _path;
    }

開發中遇到的問題,分享一下,如果對您有幫助,那便是最好;如果有錯,還望多多指出

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,406評論 6 538
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,034評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,413評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,449評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,165評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,559評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,606評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,781評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,327評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,084評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,278評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,849評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,495評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,927評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,172評論 1 291
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,010評論 3 396
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,241評論 2 375

推薦閱讀更多精彩內容