html+js 實現markdown編輯器效果

markdown的Editor.md插件官方網站:https://pandao.github.io/edit...

一:下載Editor.md

1:進入官網直接進行下載

github下載地址:https://github.com/pandao/edi...

2:使用npm進行下載

npm install editor.md

下載下來的文件結構如下:
image.png
二:Editor.md的簡單使用

1:前提:

引入css

<link rel="stylesheet" href="editormd/css/editormd.css" />

引入js

<script src="js/jquery.min.js"></script>
<script src="editormd/editormd.min.js"></script>

2:html+js實現markdown效果

<link rel="stylesheet" href="editormd/css/editormd.css" />
<div id="test-editor">
<textarea style="display:none;" class="content-markdown" name="content-markdown"></textarea>
</div>
<script src="js/jquery.min.js"></script>
<script src="editormd/editormd.min.js"></script>
<script type="text/javascript">
    $(function() {
      var editor = editormd("test-editor", {
        width  : "100%",            //寬度,不填爲100%
        height : "500px",           //高度,不填爲100%
        theme : "dark",             //主題,不填爲默認主題
        path   : "editormd/lib/",   //editor.md插件的lib目錄地址
        saveHTMLToTextarea : true, // 保存 HTML 到 Textarea
        toolbarAutoFixed:true,      //工具欄自動固定定位的開啓與禁用
      });
    });
</script>

根據如上代碼就可以實現markdown編輯器效果
image.png
但是如上代碼沒有本地上傳圖片功能,如果你需要本地上傳圖片功能,js代碼修改如下:

$(function() {
    var editor = editormd("test-editor", {
        width  : "100%",            //寬度,不填爲100%
        height : "500px",           //高度,不填爲100%
        theme : "dark",             //主題,不填爲默認主題
        path   : "editormd/lib/",   //editor.md插件的lib目錄地址
        saveHTMLToTextarea : true, // 保存 HTML 到 Textarea
        toolbarAutoFixed:true,      //工具欄自動固定定位的開啓與禁用
        imageUpload : true,         //運行本地上傳
        imageFormats : ["jpg", "jpeg", "gif", "png", "bmp", "webp"],    //允許上傳的文件格式
        imageUploadURL : "/index.php?r=markdown/upload"                 //上傳的後臺服務器路徑
    });
});

後端上傳的簡單實現如下(這裏上傳我使用了Yii框架的intervention/image插件)

Yii::$app->response->format = Response::FORMAT_JSON;
$upload = \Intervention\Image\ImageManagerStatic::make($_FILES['editormd-image-file']['tmp_name'])->save('upload/upload.jpg');//file爲上傳表單的name名
if ($upload) {
    return [
        'success' => 1,
        'message' => '上傳成功',
        'url' => 'upload/upload.jpg'
    ];
} else {
    return [
        'success' => 0,
        'message' => '上傳失敗',
    ];
}

根據如上代碼就可以實現在markdown編輯器中上傳本地圖片

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章