基於jeesite的cms系統(五):wangEditor富文本編輯器

1、關於wangEditor:javascript

wangEditor —— 輕量級 web 富文本編輯器,配置方便,使用簡單。支持 IE10+ 瀏覽器。css

 

2、建立wangEditorhtml

editor建立十分簡單隻須要引入js文件(這裏注意要加上版本號,具體緣由不詳),進行一些配置便可前端

由於這裏使用的是Beetl模板表單,因此使用textarea來接收wangEditor的值java

var $textarea = $('#textarea')
editor.customConfig.onchange = function (html) {
// 監控變化,同步更新到 textarea
$textarea.val(html)
}
<% layout('/layouts/default.html', {title: '發佈文章', libs: ['validate','fileupload','ueditor','dataGrid']}){ %>
<div class="main-content">
    <div class="box box-main">
        <div class="box-header with-border">
            <div class="box-title">
                <i class="fa fa-list-alt"></i> ${testData.isNewRecord ? '編輯文章' : '編輯文章'}
            </div>
            <div class="box-tools pull-right">
                <button type="button" class="btn btn-box-tool" data-widget="collapse"><i class="fa fa-minus"></i></button>
            </div>
        </div>
        <#form:form id="inputForm"  action="${ctx}/cms/articles/post" method="post" class="form-horizontal">
        <div class="box-body">
            <div class="row">
                <div class="col-xs-12">
                    <div class="form-group">
                        <label class="control-label col-sm-2" title="">
                            <span class="required hide">*</span> 標題:<i class="fa icon-question hide"></i></label>
                        <div class="col-sm-10">
                            <#form:input path="title" maxlength="200" class="form-control"/>
                        </div>
                    </div>
                </div>
            </div>
            <div class="row">
                <div class="col-xs-12">
                    <div class="form-group">
                        <label class="control-label col-sm-2" title="">
                            <span class="required hide">*</span> 內容:<i class="fa icon-question hide"></i></label>
                        <div class="col-sm-10" style="height: 1030px">
                            <#form:hidden path="content" id="textarea"/>
                            <div id="editor"></div>
                        </div>
                    </div>
                </div>
            </div>
            <div class="row">
                <div class="col-xs-6">
                    <div class="form-group">
                        <label class="control-label col-sm-4" title="">
                            <span class="required hide">*</span> 做者ID:<i class="fa icon-question hide"></i></label>
                        <div class="col-sm-8">
                            <#form:input path="authorId" maxlength="50" class="form-control"/>
                        </div>
                    </div>
                </div>
                <div class="col-xs-6">
                    <div class="form-group">
                        <label class="control-label col-sm-4" title="">
                            <span class="required hide">*</span> 路徑:<i class="fa icon-question hide"></i></label>
                        <div class="col-sm-8">
                            <#form:input path="path" maxlength="50" class="form-control"/>
                        </div>
                    </div>
                </div>
            </div>
            <div class="row">
                <div class="col-xs-12">
                    <div class="form-group">
                        <label class="control-label col-sm-2" title="">
                            <span class="required hide">*</span> 標籤:<i class="fa icon-question hide"></i></label>
                        <div class="col-sm-10">
                            <#form:input path="tags" maxlength="50" class="form-control"/>
                        </div>
                    </div>
                </div>
            </div>
        </div>
        <div class="box-footer">
            <div class="row">
                <div class="col-sm-offset-2 col-sm-10">
                    <% if (hasPermi('test:testData:edit')){ %>
                    <button type="submit" class="btn btn-sm btn-primary" id="btnSubmit"><i class="fa fa-check"></i> 發 布</button>&nbsp;
                    <% } %>
                    <button type="button" class="btn btn-sm btn-default" id="btnCancel" onclick="js.closeCurrentTabPage()"><i class="fa fa-reply-all"></i> 關 閉</button>
                </div>
            </div>
        </div>
    </#form:form>
</div>
</div>
<% } %>
<script type="text/javascript" src="/static/common/wangEditor/wangEditor.js?V4.1-01161701"></script>
<script type="text/javascript">
    // 初始化wangEditor
    var E = window.wangEditor
    var editor = new E('#editor')

    // 自定義菜單配置
    // editor.customConfig.menus = [
    // 'bold',  // 粗體
    // 'fontSize',  // 字號
    // 'italic',  // 斜體
    // 'foreColor',  // 文字顏色
    // 'link',  // 插入連接
    // 'quote',  // 引用
    // 'emoticon',  // 表情
    // 'image',  // 插入圖片
    // 'code',  // 插入代碼
    // ]

    // 上傳圖片到服務器
    // editor.customConfig.uploadImgShowBase64 = true
    // editor.customConfig.qiniu = true
    editor.customConfig.uploadFileName = 'myFileName'
    editor.customConfig.uploadImgServer = '/upload'
    editor.customConfig.uploadImgHooks = {
    customInsert: function (insertImg, result, editor) {
    var url =result.data;
    insertImg(url);
    }
    }
    var $textarea = $('#textarea')
    editor.customConfig.onchange = function (html) {
        // 監控變化,同步更新到 textarea
        $textarea.val(html)
    }
    editor.create()
    // 初始化 textarea 的值
    $textarea.val(editor.txt.html())
    $(".w-e-text-container").css("height", "1000px");
    $(".w-e-toolbar").css('font-size','16px');
    $(".col-sm-2").css("width","11.66666667%");
    $(".col-sm-4").css("width","23.33333333%");
    $(".col-sm-offset-2").css("margin-left","11.66666667%");
</script>
<script>
    $("#inputForm").validate({
        submitHandler: function(form){
        js.ajaxSubmitForm($(form), function(data){
            js.showMessage(data.message);
            if(data.result == Global.TRUE){
                js.closeCurrentTabPage(function(contentWindow){
                    contentWindow.page();
                });
            }
        }, "json");
            // js.showMessage('文章發佈成功');
        }
    });
</script>

若是不用beetl表單,只須要這樣git

var comments = editor.txt.html();

來接收數據github

 

2、文件上傳類web

wangEditor接受Map返回集ajax

package com.jeesite.modules.cms.web;

import java.io.File;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;
import javax.servlet.http.HttpServletRequest;

import com.jeesite.modules.cms.utils.PathUtil;
import org.springframework.stereotype.Controller;
import org.springframework.util.FileCopyUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;

/**
 * @author zombie
 */
@Controller
public class UploadController {

    @RequestMapping("/upload")
    @ResponseBody
    public Map<String, String> upload(@RequestParam(value="myFileName") MultipartFile file, HttpServletRequest request) {
        Map<String, String> map = new HashMap<String, String>();
        String separator = System.getProperty("file.separator");

        // 用於前端圖片顯示的路徑  http://localhost:8080/upload/
        String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + request.getContextPath()
                + separator +"upload" + separator;
        // 用於保存圖片至項目的路徑 D:\_eclipsework\.metadata\.plugins\org.eclipse.wst.server.core\tmp2\wtpwebapps\JYSystem\ upload\
        // 或者 String uploadDir = request.getSession().getServletContext().getRealPath("upload") + separator;
        String uploadDir = PathUtil.getProjectPath() + separator +"upload" + separator;

        byte[] bytes = null;
        try {

            bytes = file.getBytes();
            File dirPath = new File(uploadDir);
            if (!dirPath.exists()) {
                if (!dirPath.mkdirs()) {
                }
            }

            /**
             * 構建新的圖片名稱
             */
            String fileName = file.getOriginalFilename();
            int index = fileName.lastIndexOf(".");
            String extName = index > -1 ? fileName.substring(index) : ""; // .jpg
            String uuid = UUID.randomUUID().toString().trim().replaceAll("-", "");
            String newFileName = uuid + extName;

            /**
             * 保存圖片至項目
             */
            String filePath = uploadDir + newFileName;
            File descFile = new File(filePath);
            FileCopyUtils.copy(bytes, descFile);

            map.put("data", basePath + newFileName);
        } catch (IOException e) {
            e.printStackTrace();
        }

        return map;
    }

}

 

5、修改視圖渲染路徑spring

開始在這裏路徑老是報錯,一度覺得是/cms的問題,結果發現是把返回的postArticle.html拼寫錯了

package com.jeesite.modules.cms.web;

import com.jeesite.common.web.BaseController;
import com.jeesite.modules.test.entity.TestData;
import com.jeesite.modules.test.service.TestDataService;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
@RequestMapping(value = "${adminPath}/cms")
public class CmsController extends BaseController {

    @Autowired
    private TestDataService testDataService;

    /**
     * 獲取數據
     */
    @ModelAttribute
    public TestData get(String id, boolean isNewRecord) {
        return testDataService.get(id, isNewRecord);
    }

    /**
     * Form
     */
    @RequiresPermissions("test:testData:view")
    @RequestMapping(value = "form/postArticle")
    public String form(TestData testData, Model model) {
        return "templates/postArticle";
    }
}

 

 

 

相關文章
相關標籤/搜索