laravel富文本编辑器使用&上传图片

wangeditor富文本编辑器: http://www.wangeditor.com/

案例使用laravel框架

1、定义2个路由

// /routes/web.php
Route::get('/test','Test\TestController@index');

// /routes/api.php
Route::post('/editor/upload/picture', 'Test\TestController@editorUploadPicture');
//编辑器上传图片,放到api中可以避免csrf校验

2、控制器

<?php

namespace App\Http\Controllers\Test;

use App\Http\Controllers\Controller;
use Illuminate\Http\Request;

class TestController extends Controller
{
    public function index()
    {
        return view('index');
    }

    //编辑器上传图片
    public function editorUploadPicture(Request $request)
    {
        $directory = $request->input('directory','editor-upload/');

        if(!$request->hasFile('picture')){
            return json_encode(['errno'=>0,'msg'=>'no file','data'=>[]]);
        }

        $picture = $request->file('picture');

        if($picture->isValid()) {
            $extension = $picture->getClientOriginalExtension();//获得上传文件后缀
            $newName = date('YmdH').'-' . mt_rand(1000, 9999) . '.' . $extension;

            $picture->move($directory, $newName);//上传文件到服务器指定目录,并重命名
            $picturePath = '/'.$directory . $newName; //给用户一个相对路径

            return json_encode(['errno'=>0,'msg'=>'ok','data'=>[$picturePath]]);
        }
        return json_encode(['errno'=>0,'msg'=>'error','data'=>[]]);
    }
}

3、视图

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script type="text/javascript" src="/js/jquery-1.7.1.min.js"></script>
    <script src="//unpkg.com/wangeditor/release/wangEditor.min.js"></script>
</head>
<body>
<div class="col-lg-10">
    <div id="ContentHtml"></div>
    <textarea id="Content" name="content" style="display: none;"></textarea>
</div>

<script type="text/javascript">
    $(function(){
        //--富文本编辑器 start
        var E = window.wangEditor;
        var editor = new E('#ContentHtml');
        var $text1 = $('#Content');

        editor.customConfig.uploadImgShowBase64 = true;   // 使用 base64 保存图片
        editor.customConfig.uploadImgServer = '/api/editor/upload/picture?directory=editor-upload/';  // 上传图片到服务器
        editor.customConfig.uploadFileName = 'picture';

        editor.customConfig.onchange = function (html) {
            $text1.val(html);// 监控变化,同步更新到 textarea
        };
        editor.create();
        $text1.val(editor.txt.html());// 初始化 textarea 的值
        //--富文本编辑器 end
    });
</script>
</body>
</html>

4、效果

1337572-20190716164728435-2036496569.png

1337572-20190716164739059-1432762208.png

转载于:https://www.cnblogs.com/mg007/p/11195931.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值