成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

laravel框架學習之路(三)Laravel Datatables的使用

sean / 2500人閱讀

摘要:我們知道,做后臺管理系統(tǒng)需要很多表格用來展示我們的數(shù)據(jù),筆者在項目中使用過,對于快速開發(fā)來說,將是一個不錯的選擇。

我們知道,做后臺管理系統(tǒng)需要很多表格用來展示我們的數(shù)據(jù),筆者在tp項目中使用過datatables,對于快速開發(fā)來說,datatables將是一個不錯的選擇。
首先來看一下最終的效果:

準備工作:
1、首先,確保你的laravel配置正確(站點能夠正常訪問、數(shù)據(jù)庫連接正常...)
2、下載Datatables資源文件(AdminLTE中包含了Datatables資源文件,讀者使用其他模板需另行引入的請自行百度),并在頁面中引入,確保資源文件能夠正確加載。
3、文檔:Laravel Datatables開發(fā)文檔

系統(tǒng)要求:
Laravel 5.5+
jQuery DataTables v1.10.x

ok,開始動手?。ㄒ詀dministrator頁面為例)
1、安裝composer包

composer require yajra/laravel-datatables-oracle:^8.0

如果你需要使用datatables的全部插件可使用以下命令安裝

composer require yajra/laravel-datatables:^1.0

2、配置Datatables(此步驟可省,但還是配置下,確保后續(xù)不會出錯)
安裝完成之后,打開config/app.php,鍵入如下代碼

"providers" => [
    // ...
    YajraDataTablesDataTablesServiceProvider::class,
],

使用命令發(fā)布配置和資源文件

php artisan vendor:publish --tag=datatables

3、創(chuàng)建administrator模型

php artisan make:model Models/Administrator -m

編輯數(shù)據(jù)庫遷移文件

engine = "InnoDB";
            $table->increments("id");
            $table->string("login_name")->unique();
            $table->string("display_name");
            $table->string("password");
            $table->string("avatar")->nullable();
            $table->rememberToken();
            $table->tinyInteger("status")->default(1);
            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists("administrators");
    }
}

4、創(chuàng)建AdministratorDatatable

php artisan datatables:make Administrator

此命令會生成DataTables/AdministratorDatatable.php,打開并編輯:

setRowClass("text-center")
            ->editColumn("avatar", function (Administrator $administrator) {
                return "avatar."">";
            })
            ->editColumn("roles", function (Administrator $administrator) {
                return $administrator->roles->map(function ($role) {
                    return "".$role->identifier."[".$role->name."]"."";
                })->implode("");
            })
            ->editColumn("status", function (Administrator $administrator) {
                if ($administrator->status == 1) {
                    return "正常";
                }
                return "禁用";
            })
            ->rawColumns(["avatar", "status", "roles", "action"])
            ->addColumn("action", function (Administrator $administrator) {
                $edit_path = admin_base_path("auth/administrators/".$administrator->id."/edit");
                $delete_path = admin_base_path("auth/administrators/".$administrator->id);
                return "".
                        " 編輯".
                    "".
                    " 刪除";
            });
    }

    /**
     * Get query source of dataTable.
     *
     * @param AppModelsAdministrator $model
     * @return IlluminateDatabaseEloquentBuilder
     */
    public function query(Administrator $model)
    {
        return $model->newQuery()->select("id", "login_name", "display_name",
            "avatar", "status", "created_at", "updated_at");
    }

    /**
     * Optional method if you want to use html builder.
     *
     * @return YajraDataTablesHtmlBuilder
     */
    public function html()
    {
        return $this->builder()
            ->addTableClass("table-bordered table-striped")
            ->columns($this->getColumns())
            ->minifiedAjax("administrators")
            ->addAction(["title" => "操作", "class" => "text-center"])
            ->parameters([
                "dom" => "Bfrtip",
                "buttons" => [
                    ["extend" => "create", "text" => " 創(chuàng)建"],
                    ["extend" => "excel", "text" => " 導(dǎo)出"],
                    ["extend" => "print", "text" => " 打印"],
                    ["extend" => "reload", "text" => " 刷新"],
                ],
            ]);
    }

    /**
     * 獲取數(shù)據(jù)列
     *
     * @return array
     */
    protected function getColumns()
    {
        return [
            ["name" => "id", "data" => "id", "title" => "ID", "class" => "text-center"],
            ["name" => "login_name", "data" => "login_name", "title" => "登錄名", "class" => "text-center", "orderable" => false],
            ["name" => "display_name", "data" => "display_name", "title" => "顯示名", "class" => "text-center", "orderable" => false],
            ["name" => "avatar", "data" => "avatar", "title" => "頭像", "class" => "text-center", "orderable" => false],
            ["name" => "status", "data" => "status", "title" => "狀態(tài)", "class" => "text-center"],
            ["name" => "roles", "data" => "roles", "title" => "角色", "class" => "text-center", "orderable" => false],
            ["name" => "created_at", "data" => "created_at", "title" => "創(chuàng)建時間", "class" => "text-center"],
            ["name" => "updated_at", "data" => "updated_at", "title" => "更新時間", "class" => "text-center"],
        ];
    }

    /**
     * 設(shè)置導(dǎo)出文件名
     *
     * @return string
     */
    protected function filename()
    {
        return "Administrator_" . date("YmdHis");
    }

    /**
     * 打印列
     * @var array
     */
    protected $printColumns = ["id", "login_name", "display_name", "created_at", "updated_at"];
}

5、創(chuàng)建視圖文件resource/views/admin/auth/administrator/index.blade.php(視圖文件使用布局,讀者可參考之前的文章或參考源碼)

@extends("admin::layouts.layout")

@section("content")

    
    

管理員 列表

{!! $dataTable->table() !!}
{!! $dataTable->scripts() !!} @endsection

創(chuàng)建視圖文件resource/views/admin/auth/administrator/create.blade.php

@extends("admin::layouts.layout")

@section("content")

    
    

管理員 創(chuàng)建

@csrf
@if ($errors->has("login_name"))
{{ $errors->first("login_name") }}
@endif
@if ($errors->has("display_name"))
{{ $errors->first("display_name") }}
@endif
@if ($errors->has("roles"))
{{ $errors->first("permissions") }}
@endif
{{--
--}} {{--
--}} {{----}} {{--
--}} {{----}} {{--
--}} {{--
--}} {{--
--}}
@if ($errors->has("password"))
{{ $errors->first("password") }}
@endif
@if ($errors->has("password_confirmation"))
{{ $errors->first("password_confirmation") }}
@endif
@endsection

創(chuàng)建視圖文件resource/views/admin/auth/administrator/edit.blade.php

@extends("admin::layouts.layout")

@section("content")

    
    

管理員 編輯

id }}" method="post"> @method("PATCH") @csrf
@if ($errors->has("roles"))
{{ $errors->first("permissions") }}
@endif
{{--
--}} {{--
--}} {{----}} {{--
--}} {{----}} {{--
--}} {{--
--}} {{--
--}}
@endsection

6、創(chuàng)建administrator控制器

php artisan make:controller Admin/Auth/AdministratorController --resource

打開Admin/Auth/AdministratorController.php并編輯

render(admin_view_path("auth.administrator.index"));
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return IlluminateHttpResponse
     */
    public function create()
    {
        $roles = Role::all();
        return view(admin_view_path("auth.administrator.create"))->with([
            "roleList" => $roles,
        ]);
    }


    /**
     *
     * @param Request $request
     * @return IlluminateHttpRedirectResponse|IlluminateRoutingRedirector
     * @throws Exception
     */
    public function store(Request $request)
    {
        $this->validate($request, [
            "login_name" => "required|unique:administrators",
            "display_name" => "required",
            "roles" => "required",
            "password" => "required|min:6|confirmed",
            "password_confirmation" => "required|min:6",
        ],[
            "login_name.required" => "請輸入登錄名",
            "login_name.unique" => "該登錄名已存在",
            "display_name.required" => "請輸入顯示名",
            "roles.required" => "請選擇一個或多個角色",
            "password.required" => "請輸入密碼",
            "password.min" => "密碼至少6位",
            "password.confirmed" => "兩次輸入密碼不一致",
            "password_confirmation.required" => "請輸入確認密碼",
            "password_confirmation.min" => "密碼至少6位",
        ]);
        $administrator = new Administrator();
        $administrator->login_name = $request->get("login_name");
        $administrator->display_name = $request->get("display_name");
        $administrator->password = Hash::make($request->get("password"));
        $roles = $request->get("roles");

        DB::beginTransaction();
        try {
            if (!$administrator->save()) {
                throw new Exception("保存失敗");
            }
            if (!$administrator->updateRelation($roles)) {
                throw new Exception("保存失敗");
            }
            DB::commit();
            admin_toastr("角色更新成功!");
            return redirect(admin_base_path("auth/administrator"));
        } catch (Exception $e) {
            $error = $e->getMessage();
            DB::rollBack();
            admin_toastr($error, "error");
            return redirect()->back()->withInput()->withErrors([
                "error" => $error
            ]);
        }
    }

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return IlluminateHttpResponse
     */
    public function show($id)
    {

    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param  int  $id
     * @return IlluminateHttpResponse
     */
    public function edit($id)
    {
        $administrator = Administrator::find($id);
        $roles = Role::all();
        return view(admin_base_path("auth.administrator.edit"))->with([
            "roleList" => $roles,
            "administrator" => $administrator
        ]);
    }

    /**
     * @param Request $request
     * @param $id
     * @return IlluminateHttpRedirectResponse|IlluminateRoutingRedirector
     * @throws Exception
     */
    public function update(Request $request, $id)
    {
        $this->validate($request, [
            "login_name" => "required|unique:administrators",
            "display_name" => "required",
            "roles" => "required",
        ],[
            "login_name.required" => "請輸入登錄名",
            "login_name.unique" => "該登錄名已存在",
            "display_name.required" => "請輸入顯示名",
            "roles.required" => "請選擇一個或多個角色",
        ]);
        $administrator = Administrator::find($id);
        $administrator->login_name = $request->get("login_name");
        $administrator->display_name = $request->get("display_name");
        $roles = $request->get("roles");

        DB::beginTransaction();
        try {
            if (!$administrator->save()) {
                throw new Exception("保存失敗");
            }
            if (!$administrator->updateRelation($roles)) {
                throw new Exception("保存失敗");
            }
            DB::commit();
            admin_toastr("角色更新成功!");
            return redirect(admin_base_path("auth/administrator"));
        } catch (Exception $e) {
            $error = $e->getMessage();
            DB::rollBack();
            admin_toastr($error, "error");
            return redirect()->back()->withInput()->withErrors([
                "error" => $error
            ]);
        }
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return IlluminateHttpResponse
     */
    public function destroy($id)
    {
        if (Administrator::find($id)->delete()) {
            return response()->json([
                "status"  => true,
                "message" => "刪除成功!",
            ]);
        } else {
            return response()->json([
                "status"  => false,
                "message" => "刪除失敗,請重試!",
            ]);
        }
    }
}

別忘了配置路由:

 config("admin.route.prefix"),
    "namespace"     => config("admin.route.namespace"),
    "middleware"    => config("admin.route.middleware"),
], function (Router $router) {
    //后臺控制面板
    $router->get("/", "HomeHomeController@index")->name("home.index");
    //登錄頁面
    $router->get("login", "AuthLoginController@getLogin")->name("login.getLogin");
    //登錄
    $router->post("login", "AuthLoginController@postLogin")->name("login.postLogin");
    //注銷登錄
    $router->post("logout", "AuthLoginController@postLogout")->name("login.logout");

    /**
     * auth模塊
     */
    //后臺用戶管理
    $router->resource("auth/administrators", "AuthAdministratorController");
    //權(quán)限管理
    $router->resource("auth/permissions", "AuthPermissionController");
    //權(quán)限策略管理
    $router->resource("auth/policies", "AuthPolicyController");
    //角色管理
    $router->resource("auth/roles", "AuthRoleController");
    //菜單管理
    $router->resource("auth/menus", "AuthMenuController");

    /**
     * blog模塊
     */
    //文章管理
    $router->resource("blog/articles", "BlogArticleController");
});

7、本地化:創(chuàng)建一個多帶帶文件,如datatable-language.js并在頁面中引入

$.fn.dataTable.defaults.oLanguage = {

    "sProcessing": "處理中...",
    "sLengthMenu": "顯示 _MENU_ 項結(jié)果",
    "sZeroRecords": "沒有匹配結(jié)果",
    "sInfo": "顯示第 _START_ 至 _END_ 項結(jié)果,共 _TOTAL_ 項",
    "sInfoEmpty": "顯示第 0 至 0 項結(jié)果,共 0 項",
    "sInfoFiltered": "(由 _MAX_ 項結(jié)果過濾)",
    "sInfoPostFix": "",
    "sSearch": "搜索:",
    "sUrl": "",
    "sEmptyTable": "表中數(shù)據(jù)為空",
    "sLoadingRecords": "載入中...",
    "sInfoThousands": ",",
    "oPaginate": {
        "sFirst": "首頁",
        "sPrevious": "上頁",
        "sNext": "下頁",
        "sLast": "末頁"
    },
    "oAria": {
        "sSortAscending": ": 以升序排列此列",
        "sSortDescending": ": 以降序排列此列"
    }
};

$.fn.dataTable.defaults.autoWidth = false;

寫在最后:表格中一些按鈕事件請讀者根據(jù)需要自行編碼,這里只給出一個例子:刪除按鈕事件(引入了sweetalert插件以及toastr插件,如有需要請參考源碼)

//datatables刪除按鈕
$("#pjax-container").on("click", ".row-delete", function () {
    var del_url = $(this).data("url");
    swal({
        title: "確定刪除此項?",
        type: "warning",
        showCancelButton: true,
        confirmButtonColor: "#DD6B55",
        confirmButtonText: "確 定",
        closeOnConfirm: false,
        cancelButtonText: "取 消"
    }, function(){
        $.ajax({
            method: "post",
            url: del_url,
            data: {
                _method:"delete",
                _token:csrf_token,
            },
            success: function (data) {
                if (typeof data === "object") {
                    if (data.status) {
                        swal(data.message, "", "success");
                        $.pjax.reload("#pjax-container");
                    } else {
                        swal(data.message, "", "error");
                    }
                }
            }
        });
    });
});

ok,大功告成,enjoy it !
下載:項目源碼

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/107809.html

相關(guān)文章

  • laravel框架學習之路Laravel Datatables使用

    摘要:我們知道,做后臺管理系統(tǒng)需要很多表格用來展示我們的數(shù)據(jù),筆者在項目中使用過,對于快速開發(fā)來說,將是一個不錯的選擇。 我們知道,做后臺管理系統(tǒng)需要很多表格用來展示我們的數(shù)據(jù),筆者在tp項目中使用過datatables,對于快速開發(fā)來說,datatables將是一個不錯的選擇。首先來看一下最終的效果:showImg(https://segmentfault.com/img/bVbbpf0?...

    Lin_YT 評論0 收藏0
  • laravel框架學習之路Laravel Datatables使用

    摘要:我們知道,做后臺管理系統(tǒng)需要很多表格用來展示我們的數(shù)據(jù),筆者在項目中使用過,對于快速開發(fā)來說,將是一個不錯的選擇。 我們知道,做后臺管理系統(tǒng)需要很多表格用來展示我們的數(shù)據(jù),筆者在tp項目中使用過datatables,對于快速開發(fā)來說,datatables將是一個不錯的選擇。首先來看一下最終的效果:showImg(https://segmentfault.com/img/bVbbpf0?...

    kbyyd24 評論0 收藏0
  • laravel框架學習之路Laravel Datatables使用

    摘要:我們知道,做后臺管理系統(tǒng)需要很多表格用來展示我們的數(shù)據(jù),筆者在項目中使用過,對于快速開發(fā)來說,將是一個不錯的選擇。 我們知道,做后臺管理系統(tǒng)需要很多表格用來展示我們的數(shù)據(jù),筆者在tp項目中使用過datatables,對于快速開發(fā)來說,datatables將是一個不錯的選擇。首先來看一下最終的效果:showImg(https://segmentfault.com/img/bVbbpf0?...

    CompileYouth 評論0 收藏0
  • laravel框架學習之路(二)pjax使用

    摘要:繼第一篇文章發(fā)布之后框架學習之路一前后臺用戶認證分離,忙著項目上的事情,一直沒有時間寫文章。進入到新公司后,忙里偷閑,繼續(xù)我的框架學習之路。附件筆者的布局全局文件整頁刷新時,菜單顯示刪除按鈕確定刪除此項確定取消 繼第一篇文章發(fā)布之后laravel框架學習之路(一)前后臺用戶認證分離,忙著項目上的事情,一直沒有時間寫文章。進入到新公司后,忙里偷閑,繼續(xù)我的laravel框架學習之路。如需...

    lily_wang 評論0 收藏0
  • laravel框架學習之路(二)pjax使用

    摘要:繼第一篇文章發(fā)布之后框架學習之路一前后臺用戶認證分離,忙著項目上的事情,一直沒有時間寫文章。進入到新公司后,忙里偷閑,繼續(xù)我的框架學習之路。附件筆者的布局全局文件整頁刷新時,菜單顯示刪除按鈕確定刪除此項確定取消 繼第一篇文章發(fā)布之后laravel框架學習之路(一)前后臺用戶認證分離,忙著項目上的事情,一直沒有時間寫文章。進入到新公司后,忙里偷閑,繼續(xù)我的laravel框架學習之路。如需...

    gotham 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<