原文连接:https://www.wjcms.net/archives/laravel支持markdown编辑器解决方案
laravel-markdown-editor--markdown编辑器
说明
此扩展包兼容laravel5.8以上版本
准备工作
安装扩展包
composer require wjcms/laravel-markdown-editor
配置providers
//cconfig/app.php
'providers' => [
//添加如下一行
wjcmslaravelmdLaravelmdServiceProvider::class,
]
拷贝相关文件到项目文件夹中
php artisan vendor:publish --provider="wjcmslaravelmdLaravelmdServiceProvider"
使用
1.在blade模版引入
@include('layouts.md.md')
2.父模版中需要添加上
#注意在scripts上边需要引入jquery
@stack('styles')
@stack('scripts')
3.修改md.blade.php文件的 imageUploadURL修改为接口路径
4.创建service服务uploadservice.php,实现如下方法。
public function upload(UploadedFile $file)
{
$path = '/uploads/'.$file->store(date('y/m'), 'uploads');
return $this->save($file, $path);
}
//注意这里还需要创建Attachment模型和数据库(包含path,extension,name三个字段)
protected function save(UploadedFile $file, $path)
{
return Attachment::create([
'path'=>$path,
'extension'=>$file->extension(),
'name'=>$file->getClientOriginalName()
]);
}
5.admin控制器创建方法
/**
* 图片上传方法
*/
public function uploadPic(Request $request, UploadService $uploadService)
{
$res = $uploadService->upload($request->file('editormd-image-file'));
return response()->json([
'success'=>1,
'message'=>'图片上传成功',
'url'=> $res->path
]);
}
6.routes/web.php文件添加路由
use AppHttpControllersAdmin;
//注意这里是laravel8的写法,之前版本自行修改
Route::prefix('admin')->name('admin.')->group(function () {
Route::post('upload', [AdminAdminController::class,'uploadPic'])->name('upload');
}
就可以发现markdown编辑器可以使用了。