摘要:多圖上傳修改里面的方法將封面修改為封面創(chuàng)建圖片修改器修改器使用說(shuō)明,請(qǐng)閱讀相關(guān)說(shuō)明文檔在里增加和兩個(gè)方法顯示效果原文地址地址
laravel中使用WangEditor及多圖上傳 1. 創(chuàng)建項(xiàng)目及安裝所需安裝包 1.1 創(chuàng)建項(xiàng)目
composer create-project laravel/laravel=5.3 blog_wangeditor --prefer-dist1.2 創(chuàng)建數(shù)據(jù)庫(kù)及配置文件
vim .env1.3 安裝中文包
composer require "caouecs/laravel-lang:~3.0"
安裝之后將語(yǔ)言包移動(dòng)到對(duì)應(yīng)位置就好了,語(yǔ)言包默認(rèn)位置是resources/lang
cp -a vendor/caouecs/laravel-lang/src/zh-CN resources/lang
修改config/app.php將local的值改為zh-CN
1.4 安裝laravel-admincomposer 安裝
composer require encore/laravel-admin "1.3.*"
在config/app.php加入ServiceProvider:
EncoreAdminProvidersAdminServiceProvider::class
發(fā)布資源
php artisan vendor:publish --tag=laravel-admin
安裝
php artisan admin:install1.5 快速生成前端登錄注冊(cè)模塊
php artisan make:auth
執(zhí)行遷移
php artisan migrate2. 快速生成文章管理 2.1 創(chuàng)建遷移表
php artisan make:migration create_posts_table --create=posts2.2 修改遷移表database/2018_01_14_191442_create_posts_table.php
public function up() { Schema::create("posts", function (Blueprint $table) { $table->increments("id"); $table->text("title"); $table->text("subtitle"); $table->text("cover"); $table->enum("type", ["0", "1", "2", "3", "4", "5", "9"])->default("0"); $table->text("content"); $table->timestamps(); }); }2.3 執(zhí)行遷移
php artisan migrate2.4 創(chuàng)建模型和控制器
模型
php artisan make:model AppModelsPost
控制器
php artisan admin:make PostController --model=AppModelsPost2.5 新增文章后臺(tái)路由
Admin/routes.php
$router->resource("/post", "PostController");2.6 修改app/Admin/PostController.php里面的form和grid兩個(gè)方法
protected function grid() { return Admin::grid(Post::class, function (Grid $grid) { $grid->id("ID")->sortable(); $grid->title("標(biāo)題"); $grid->subtitle("副標(biāo)題"); $grid->type("類型")->options([ "0" => "php", "1" => "laravel", "2" => "javascript", "3" => "python", "4" => "golang", "5" => "linux", "9" => "other" ]); $grid->cover("封面")->image("/uploads", 100, 100); $grid->content("內(nèi)容")->limit(100); $grid->created_at("創(chuàng)建時(shí)間"); $grid->updated_at("修改時(shí)間"); }); } protected function form() { return Admin::form(Post::class, function (Form $form) { $form->display("id", "ID"); $form->text("title", "標(biāo)題"); $form->textarea("subtitle", "副標(biāo)題")->rows(3); $form->select("type", "類型")->options([ "0" => "php", "1" => "laravel", "2" => "javascript", "3" => "python", "4" => "golang", "5" => "linux", "9" => "other" ]); $form->image("cover", "封面"); $form->editor("content", "內(nèi)容"); $form->display("created_at", "創(chuàng)建時(shí)間"); $form->display("updated_at", "修改時(shí)間"); }); }3. 集成WangEditor編輯器 3.1 移除已有組件
修改app/Admin/bootstrap.php
3.2 集成富文本編輯器wangEditor先下載前端庫(kù)文件wangEditor,解壓到目錄public/vendor/wangEditor-3.0.9。
然后新建組件類app/Admin/Extensions/WangEditor.php。
關(guān)于WangEditor設(shè)置部分請(qǐng)閱讀官方文檔formatName($this->column); $this->script = <<id}"); editor.customConfig.uploadFileName = "mypic[]"; editor.customConfig.uploadImgHeaders = { "X-CSRF-TOKEN": $("input[name="_token"]").val() } editor.customConfig.zIndex = 0; // 上傳路徑 editor.customConfig.uploadImgServer = "/uploadFile"; editor.customConfig.onchange = function (html) { $("input[name=$name]").val(html); } editor.customConfig.uploadImgHooks = { customInsert: function (insertImg, result, editor) { if (typeof(result.length) != "undefined") { for (var i = 0; i <= result.length - 1; i++) { var j = i; var url = result[i].newFileName; insertImg(url); } toastr.success(result[j]["info"]); } switch (result["ResultData"]) { case 6: toastr.error("最多可以上傳4張圖片"); break; case 5: toastr.error("請(qǐng)選擇一個(gè)文件"); break; case 4: toastr.error("上傳失敗"); break; case 3: toastr.error(result["info"]); break; case 2: toastr.error("文件類型不合法"); break; case 1: toastr.error(result["info"]); break; } } } editor.create(); // var editor = new wangEditor("{$this->id}"); // editor.create(); EOT; return parent::render(); } } 新建視圖文件resources/views/admin/wang-editor.blade.php:
@include("admin::form.error"){!! old($column, $value) !!}
然后注冊(cè)進(jìn)laravel-admin,在app/Admin/bootstrap.php中添加以下代碼:
調(diào)用:
$form->editor("body");3.3 完成WangEditor圖片上傳 3.3.1 創(chuàng)建上傳路由routes/web.phpRoute::post("/uploadFile", "UploadsController@uploadImg");3.3.2 創(chuàng)建上傳文件控制器UploadsControllerphp artisan make:controller UploadsController修改appControllersUploadsController.php
file("mypic"); // dd($file); if (!empty($file)) { foreach ($file as $key => $value) { $len = $key; } if ($len > 25) { return response()->json(["ResultData" => 6, "info" => "最多可以上傳25張圖片"]); } $m = 0; $k = 0; for ($i = 0; $i <= $len; $i++) { // $n 表示第幾張圖片 $n = $i + 1; if ($file[$i]->isValid()) { if (in_array(strtolower($file[$i]->extension()), ["jpeg", "jpg", "gif", "gpeg", "png"])) { $picname = $file[$i]->getClientOriginalName();//獲取上傳原文件名 $ext = $file[$i]->getClientOriginalExtension();//獲取上傳文件的后綴名 // 重命名 $filename = time() . str_random(6) . "." . $ext; if ($file[$i]->move("uploads/images", $filename)) { $newFileName = "/" . "uploads/images" . "/" . $filename; $m = $m + 1; // return response()->json(["ResultData" => 0, "info" => "上傳成功", "newFileName" => $newFileName ]); } else { $k = $k + 1; // return response()->json(["ResultData" => 4, "info" => "上傳失敗"]); } $msg = $m . "張圖片上傳成功 " . $k . "張圖片上傳失敗3.3.3 修改config/admin.php upload里面的host
"; $return[] = ["ResultData" => 0, "info" => $msg, "newFileName" => $newFileName]; } else { return response()->json(["ResultData" => 3, "info" => "第" . $n . "張圖片后綴名不合法!
" . "只支持jpeg/jpg/png/gif格式"]); } } else { return response()->json(["ResultData" => 1, "info" => "第" . $n . "張圖片超過(guò)最大限制!
" . "圖片最大支持2M"]); } } } else { return response()->json(["ResultData" => 5, "info" => "請(qǐng)選擇文件"]); } return $return; } }"upload" => [ "disk" => "admin", "directory" => [ "image" => "image", "file" => "file", ], // 將upload改為uploads "host" => "http://localhost:8000/uploads/", ],預(yù)覽圖
可以看出WangEditor上傳多圖是沒(méi)有問(wèn)題的
可是有時(shí)候我們想給文章配多個(gè)封面圖怎么辦?
4. laravel-admin 多圖上傳 4.1 修改app/Admin/PostController里面的form()方法
下面我們就來(lái)完成,laravel-admin的多圖上傳。將$form->image("cover", "封面");
4.2 創(chuàng)建圖片修改器
修改為$form->multipleImage("cover", "封面");laravel修改器使用說(shuō)明,請(qǐng)閱讀相關(guān)說(shuō)明文檔
在app/Models/Post.php里增加setCoverAttribute()
和setCoverAttribute兩個(gè)方法attributes["cover"] = json_encode($cover); } } public function getCoverAttribute($cover) { return json_decode($cover, true); } }顯示效果
原文地址https://www.bear777.com/blog/laravel-wangeditor
github地址https://github.com/pandoraxm/laravel-admin-wangeditor
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/92480.html
摘要:多圖上傳修改里面的方法將封面修改為封面創(chuàng)建圖片修改器修改器使用說(shuō)明,請(qǐng)閱讀相關(guān)說(shuō)明文檔在里增加和兩個(gè)方法顯示效果原文地址地址 laravel中使用WangEditor及多圖上傳 1. 創(chuàng)建項(xiàng)目及安裝所需安裝包 1.1 創(chuàng)建項(xiàng)目 composer create-project laravel/laravel=5.3 blog_wangeditor --prefer-dist 1.2 創(chuàng)建...
摘要:中使用及多圖上傳下篇快速生成前臺(tái)文章創(chuàng)建路由快速生成文章控制器修改文章控制器創(chuàng)建視圖文件列表頁(yè)文章列表頁(yè)文章列表什么都沒(méi)有詳情頁(yè)詳情頁(yè)圖 laravel中使用WangEditor及多圖上傳(下篇) 1. 快速生成前臺(tái)文章 1.1 創(chuàng)建路由 Route::resource(/article, ArticleController); 1.2 快速生成文章控制器ArticleControll...
摘要:要定義這種關(guān)系,請(qǐng)打開(kāi)模型并添加一個(gè)注意模型的命名空間是所以注意要頭部引入第二個(gè)參數(shù)是數(shù)據(jù)透視表收藏夾的名稱。這將允許插入或更新行時(shí),數(shù)據(jù)透視表上的時(shí)間戳和列將受到影響。 laravel5.3 vue 實(shí)現(xiàn)收藏夾功能 ? 本篇是接著laravel中使用WangEditor及多圖上傳(下篇) 所以我們這里不演示怎么新建項(xiàng)目了。? 1. laravel項(xiàng)目安裝 ?下載之前的項(xiàng)目,完成安裝。...
摘要:要定義這種關(guān)系,請(qǐng)打開(kāi)模型并添加一個(gè)注意模型的命名空間是所以注意要頭部引入第二個(gè)參數(shù)是數(shù)據(jù)透視表收藏夾的名稱。這將允許插入或更新行時(shí),數(shù)據(jù)透視表上的時(shí)間戳和列將受到影響。 laravel5.3 vue 實(shí)現(xiàn)收藏夾功能 ? 本篇是接著laravel中使用WangEditor及多圖上傳(下篇) 所以我們這里不演示怎么新建項(xiàng)目了。? 1. laravel項(xiàng)目安裝 ?下載之前的項(xiàng)目,完成安裝。...
摘要:示例列表批量操作按鈕批量刪除全選復(fù)選框列表復(fù)選框示例部分截圖作者年月日 歡迎使用yamecent-admin后臺(tái)管理 環(huán)境要求 依賴 說(shuō)明 PHP PHP7+ 項(xiàng)目簡(jiǎn)介 yamecent-admin是一款基于laravel框架進(jìn)行封裝的后臺(tái)管理系統(tǒng),其中包含: rbac權(quán)限管理模塊 完整的ui組件(外部引入) 圖片上傳,網(wǎng)絡(luò)請(qǐng)求等常用的js公共函數(shù) 持續(xù)維護(hù)中... ...
閱讀 4186·2021-11-22 13:52
閱讀 2093·2021-09-22 15:12
閱讀 1132·2019-08-30 15:53
閱讀 3467·2019-08-29 17:12
閱讀 2198·2019-08-29 16:23
閱讀 1662·2019-08-26 13:56
閱讀 1778·2019-08-26 13:44
閱讀 1897·2019-08-26 11:56