laravel實戰化項目之三板斧javascript
laravel是我工做10多年來見到的真正能稱得上讓phper從麪條同樣雜亂的代碼中解脫出來,雖然我不是徹底的phper;並真正意義上的一個比較完美優雅的基於面向對象又mvc富有表現力的強大的PHP開發框架。html
laravel安裝配置這裏就略過不表啦。本文但願從一張表(tb_role_info 用戶角色表)的CRUD展開laravel的紳士魅力。java
開發技術選型:laravel framework5+bootstrap+mysql。mysql
項目目錄結構:jquery
喔忘了views視圖層,存放表現頁面。laravel
(1)業務表 tb_role_infoajax
1 -- ---------------------------- 2 -- Table structure for `tb_role_info` 用戶角色表 3 -- ---------------------------- 4 DROP TABLE IF EXISTS `tb_role_info`; 5 CREATE TABLE `tb_role_info` ( 6 `id` int(11) NOT NULL AUTO_INCREMENT, 7 `role_name` varchar(32) NOT NULL DEFAULT '' COMMENT '角色名稱', 8 `role_mark` varchar(255) DEFAULT '' COMMENT '角色備註', 9 `creater_id` int(11) NOT NULL DEFAULT '0' COMMENT '記錄建立者id', 10 `created_at` timestamp NULL DEFAULT NULL COMMENT '建立日期', 11 `updated_at` timestamp NULL DEFAULT NULL COMMENT '更新日期', 12 `time_stamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '記錄更新時間戳', 13 PRIMARY KEY (`id`), 14 KEY `tb_role_info_index` (`id`,`role_name`,`creater_id`) USING BTREE 15 ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='角色信息表';
(2)業務界面 role.blade.phpspring
<!DOCTYPE html> <html> <head> @include('backend.header') <link rel="stylesheet" type="text/css" href="{{asset('backend/plugs/bootstrap-table/src/bootstrap-table.css')}}?v={{$version}}"/> </head> <body> @include('backend.navbar') <div id="page-container"> <!-- BEGIN SIDEBAR --> @include('backend.menu') <!-- END SIDEBAR --> <!-- BEGIN RIGHTBAR --> <!-- END RIGHTBAR --> <div id="page-content"> <div id="wrap"> <div id="page-heading"> <ol class="breadcrumb"> <li><a href="#" title="icons">系統管理</a></li> <li class="active">角色信息</li> </ol> </div> <!-- container 內容顯示區域begin--> <div class="container"> <div class='data-loading'></div> <div class="row"> <div class="col-xs-12"> <div id="search_panel" class="search-panel-body"> <form id="search_form" class="form-horizontal"> <div class="row"> <div class="col-md-10"> <div class="form-group"> <label for="search_txt_roleName" class="col-sm-1 control-label">角色名稱</label> <div class="col-sm-11"> <input id="search_txt_roleName" type="text" class="form-control" placeholder="請輸入關鍵字..."> </div> </div> </div> <div class="col-md-2"> <div class="form-group"> <div class="col-sm-8"> <button id="btn_search_save" type="button" class="btn btn-primary"> <i class="fa fa-search"></i> 查詢</button> </div> <div class="col-sm-4"> <button id="btn_search_expand" type="button" class="btn btn-default"> <i class="fa fa-angle-double-up"></i></button> </div> </div> </div> </div> <div class="row" id="search_more_panel" style="display:none;"> </div> </form> </div> <div class="panel panel-gray"> <div class="panel-heading"> <h4>角色信息 </h4> <div class="options"> <div class="btn-group"> <div class="btn-group" id="table_tools_bar"> <button type="button" class="btn btn-default dropdown-toggle btn-tools" data-toggle="dropdown" title="定製列顯示"><i class="fa fa-th-list"></i> <span class="caret"></span></button> </div> <button id="btn_role_refresh" type="button" class="btn btn-default btn-tools" title="角色刷新"><i class="fa fa-refresh"></i></button> </div> </div> <div class="options options-groups"> <a href="javascript:;" id="btn_role_delete" title="角色刪除"><i class="fa fa-times"></i> 刪除</a> <a data-toggle="modal" href="#form_modal" id="btn_role_edit" title="角色編輯"><i class="fa fa-edit"></i> 編輯</a> <a data-toggle="modal" href="#form_modal" id="btn_role_add" title="角色添加"><i class="fa fa-pencil"></i> 添加</a> </div> </div> <div class="panel-body"> <div class="table-responsive"> <table id="role_table"></table> </div> <!-- add/edit modal-begin --> <div id="form_modal" class="modal fade md-trigger" data-modal="md-fade-in-scale-up" tabindex="-1" role="dialog" aria-labelledby="form_modal_title" data-keyboard="true" data-backdrop="static" aria-hidden="true"> <div id="form_modal_dialog" class="modal-dialog"> <div class="modal-content"> <div class="modal-header"> <button type="button" class="close" data-dismiss="modal" aria-hidden="true"> ×</button> <h4 class="modal-title" id="form_modal_title"></h4> </div> <div class="modal-body"> <form id="modalForm" class="form-horizontal" role="form" enctype="multipart/form-data"> <!-- 隱藏值存放區域 begin--> <input name="id" id="form_hidden_id" type="hidden"> <input name="createrId" id="form_hidden_createrId" type="hidden"> <!-- 隱藏值存放區域 end--> <div class="form-group"> <label for="form_txt_roleName" class="col-sm-2 control-label">角色名稱</label> <div class="col-sm-7"> <input id="form_txt_roleName" name="roleName" maxlength="32" placeholder="角色名稱最多32個字符" required="" type="text" class="form-control"> </div> <div class="col-sm-3"> <p class="help-block">角色名稱必填!</p> </div> </div> <div class="form-group"> <label for="form_txt_roleName" class="col-sm-2 control-label">角色權限</label> <div class="col-sm-10"> <table id="table_module" class="table table-bordered"> <thead> <tr> <th width="2%" style="padding: 10px"> </th> <th width="28%" style="padding: 10px"> 模塊 </th> <th width="30%" style="padding: 10px"> 功能 </th> <th width="30%" style="padding: 10px"> 動做 </th> </tr> </thead> @if(isset($moduleList)) <tbody> @foreach($moduleList as $module) @if($module->id==1 && $user->userRoleId!=1) @else <tr> <td> <input type="checkbox" id="power_{{$module->id}}" name="mod_{{$module->id}}" value="{{$module->id}}" onclick="checkModule({{$module->id}});" /> </td> <td> {{$module->moduleCnName}} </td> <td> <table width="100%"> @if(isset($module->children)) @foreach($module->children as $children) <tr> <td width="6%"><input type="checkbox" id="power_{{$children->id}}" name="fun_{{$module->id}}" value="{{$children->id}}" onclick="checkFun({{$module->id}});" /></td> <td width="94%">{{$children->moduleCnName}}</td> </tr> @endforeach @endif </table> </td> <td> <table width="100%"> @if(isset($module->children)) @foreach($module->children as $oneChild) @if(isset($oneChild->children)) @foreach($oneChild->children as $twoChild) <tr> <td width="6%"><input type="checkbox" id="power_{{$twoChild->id}}" name="act_{{$children->id}}" value="{{$twoChild->id}}" onclick="checkAction({{$children->id}});"/></td> <td width="94%">{{$twoChild->moduleCnName}}</td> </tr> @endforeach @endif @endforeach @endif </table> </td> </tr> @endif @endforeach </tbody> @endif </table> </div> </div> <div class="form-group"> <label for="form_txt_roleMark" class="col-sm-2 control-label"> 角色描述</label> <div class="col-sm-10"> <textarea id="form_txt_roleMark" name="roleMark" maxlength="255" placeholder="角色描述最多255個字符" class="form-control autosize"></textarea> </div> </div> </form> </div> <div class="modal-footer"> <button id="btn_role_save" type="button" class="btn btn-primary"> 肯定</button> <button type="button" class="btn btn-default" data-dismiss="modal"> 取消</button> </div> </div> <!-- /.modal-content --> </div> <!-- /.modal-dialog --> </div> <!-- add/edit modal-end --> </div> </div> </div> </div> </div> <!-- container 內容顯示區域end--> </div> <!--wrap --> </div> </div> <!-- page-container --> <!-- page-content --> @include('backend.footer') </body> </html> <script type="text/javascript" charset="utf-8" src="{{asset('backend/plugs/bootstrap-table/src/bootstrap-table.js')}}?v={{$version}}"></script> <script type="text/javascript" charset="utf-8" src="{{asset('backend/plugs/bootstrap-table/src/locale/bootstrap-table-zh-CN.js')}}?v={{$version}}"></script> <script type="text/javascript" charset="utf-8" src="{{asset('backend/js/sys_role.js')}}?v={{$version}}"></script>
(3)業務界面邏輯 sys_role.js
誰老是說用了jquery會致使你的腳本代碼像意大利麪條呀。你看像嗎?!像也只能說明你功底不夠。軟件架構設計規劃能力太差。
/** * sys_role * 角色信息 * @author steven9801@163.com * @date 2015-11-19 */ (function ($) { $(document).ready(function () { /** * 初始化 */ init(); /** * 新建模態 */ $('#btn_role_add').click(function () { addModal() }); /** * 編輯模態 */ $('#btn_role_edit').click(function () { var rowList = dataGrid.bootstrapTable('getSelections'); var length = rowList.length; if (length == 0) { warningBox('請選擇編輯對象.'); return false; } if (length > 1) { warningBox('只能編輯一項.'); return false; } editModal(rowList[0]); }); /** * 保存動做 */ $('#btn_role_save').click(function () { switch (dialogType) { case 'add': onAdd(); break; case 'edit': onEdit(); break; default: break; } }); /** * 刪除 */ $('#btn_role_delete').click(function () { onDelete(); }); //-----------------常規事件----------begin-------// /** * 刷新 */ $('#btn_role_refresh').click(function () { dataGrid.bootstrapTable('destroy'); loadGrid(); }); /** * 展開 */ $('#btn_search_expand').click(function () { $(this).html(''); searchStatus = searchStatus ? false : true; if (searchStatus) { $('#search_more_panel').hide('slow'); $(this).html('<i class="fa fa-angle-double-up"></i>'); } else { $('#search_more_panel').show('slow'); $(this).html('<i class="fa fa-angle-double-down"></i>'); } return false; }); /** * 提交查詢 */ $('#btn_search_save').click(function () { dataGrid.bootstrapTable('destroy'); bindGrid(function (params) { var roleName = $('#search_txt_roleName').val(); role.pageSize = params.pageSize; role.pageStart = params.pageSize * (params.pageNumber - 1); role.sortName = params.sortName; role.sortOrder = params.sortOrder; if (roleName.length > 0) { role.roleName = roleName; } return JSON.stringify(role); }); }); //-----------------常規事件----------end-------// }); })(jQuery); /** * 全局變量 */ //--------------------------全局變量區---------------------------// var dataGrid = null; //列表對象 var dialogType = 'add'; var role = {}; var lock = false; //防止重複提交 var searchStatus = false; //查詢面板狀態 //--------------------------全局變量區---------------------------// /** * 初始化 */ function init() { loadGrid(); $("#form_modal .modal-body").css({ height: "650px", overflowX: "hidden", overflowY: "auto" }); $('textarea.autosize').autosize({ append: "\n" }); }; /** * * 加載列表 * */ function loadGrid() { bindGrid(function (params) { return JSON.stringify({ pageSize: params.pageSize, pageStart: params.pageSize * (params.pageNumber - 1), sortName: params.sortName, sortOrder: params.sortOrder }); }); return false; }; /** * 綁定列表 */ function bindGrid(callBack) { dataGrid = $('#role_table').bootstrapTable({ method: 'POST', contentType: 'application/json;charset=utf-8', url: '../admin/role', height: 500, striped: true, pagination: true, sidePagination: 'server', pageSize: 25, pageList: [25, 50, 100, 200], showExport: true, sortName: 'createdAt', sortOrder: 'desc', minimunCountColumns: 2, formatLoadingMessage: function () { return '<img src="../../backend/images/loading.gif"/>'; }, queryParams: callBack, columns: [ { field: 'state', checkbox: true }, { field: 'roleName', title: '角色名稱', align: 'left', valign: 'middle', sortable: true }, { field: 'createdAt', title: '建立時間', align: 'center', valign: 'middle', sortable: true }, { field: 'operate', title: '操做', align: 'left', valign: 'middle', sortable: false, formatter: formatOperate, events: operateEvents } ] }); }; /** * 格式化操做列 * */ function formatOperate(value, row, index) { var content = []; content.push(' <a class="view" data-toggle="modal" href="#form_modal" title="角色查看"><i class="fa fa-eye"></i></a>'); content.push(' <a class="edit" data-toggle="modal" href="#form_modal" title="角色編輯"><i class="fa fa-edit"></i></a>'); content.push(' <a class="delete" href="javascript:void(0)" title="角色刪除"><i class="fa fa-times"></i></a>'); return content.join(''); }; /** * 操做列事件 */ window.operateEvents = { 'click .view': function (e, value, row, index) { viewModal(row); return false; }, 'click .edit': function (e, value, row, index) { editModal(row); return false; }, 'click .delete': function (e, value, row, index) { if (lock) return false; lock = true; if (userToken.id != row.createrId) { lock = false; warningBox('對不起,您無權刪除該角色.'); return false; } var ids = []; ids.push(row.id); var params = {}; params.ids = ids; deleteModal(params); } }; /** * 顯示模態 */ function showModal(action, title, width) { dialogType = action; $('.modal-footer').show(); $('#form_modal #form_modal_title').html(title); $('#form_modal_dialog').css({ width: width }); $('select,textarea,input').prop('disabled', false); $('#back-to-top').trigger('click'); return false; }; /** * 綁定模態 */ function bindModal(row) { $('#form_hidden_id').val(row.id); $('#form_hidden_createrId').val(row.createrId); $('#form_txt_roleName').val(row.roleName); $('#form_txt_roleMark').val(row.roleMark); $("input[id^='power_']").removeAttr("checked"); var roleModuleList = row.roleModuleList; for (var i in roleModuleList) { var id = roleModuleList[i]; $("input[id='power_" + id + "']").prop("checked", true); } }; /** * 查看模態 */ function viewModal(row) { showModal('view', '角色查看', '60%'); bindModal(row); $('select,textarea,input:not(.fixed-table-container input)').prop('disabled', true); $('#search_panel select,#search_panel input').prop('disabled', false); $('#table_tools_bar').find('input').prop('disabled', false); $('.modal-footer').hide(); return false; }; /** * 編輯模態 */ function editModal(row) { role = row; if (userToken.id != row.createrId) { pauseModal('#form_modal'); warningBox('對不起,您無權編輯該角色.'); return false; } showModal('edit', '角色編輯', '60%'); bindModal(row); return false; }; /** * 新建模態 */ function addModal() { showModal('add', '角色新建', '60%'); $('input[type=text],input[type=hidden],input[type=number],textarea').val(''); $('select option').eq(0).prop('selected', true); $("input[id^='power_']").prop('checked', false); return false; }; /** * 驗證表單 */ function checkForm() { if (lock) return false; lock = true; var roleName = $("#form_txt_roleName").val(); if (roleName.length == 0) { warningBox("角色名稱不能爲空."); lock = false; return false; } if (roleName.length > 32) { warningBox("角色名稱最多32個字符."); lock = false; return false; } if ($("input[id^='power_']:checkbox:checked").length == 0) { warningBox("請選擇權限."); lock = false; return false; } var roleMark = $("#form_txt_roleMark").val(); if (roleMark.length > 255) { warningBox("角色描述最多255個字符."); lock = false; return false; } var roleModuleList = []; $("input[id^='power_']:checkbox:checked").each(function () { var id = parseInt($(this).val()); roleModuleList.push(id); }); role.roleName = roleName; role.roleMark = roleMark; role.roleModuleList = roleModuleList; return true; }; /** * 角色添加 */ function onAdd() { if (!checkForm()) { return false; } $('.data-loading').show(); var task = new DelayedTask(function () { $.ajax({ cache: false, type: "POST", dataType: "json", contentType: "application/json;charset=utf-8", url: "../admin/role/add", data: JSON.stringify(role), timeout: 30000, success: function (data) { if (data) { $(".data-loading").hide(); var code = data.code; if (code != 0) { dangerBox(data.message); lock = false; return false; } lock = false; $('#form_modal').modal('hide') successBox('角色新建成功.'); $('#btn_role_refresh').trigger('click'); } return false; }, error: function (e) { if (e.status == 404) { window.location = "../../404.html"; } else if (e.status == 500) { window.location = "../../500.html"; } } }); }); task.delay(500); return false; }; /** * 角色編輯 */ function onEdit() { if (!checkForm()) { return false; } $('.data-loading').show(); var task = new DelayedTask(function () { $.ajax({ cache: false, type: "POST", dataType: "json", contentType: "application/json;charset=utf-8", url: "../admin/role/edit", data: JSON.stringify(role), timeout: 30000, success: function (data) { if (data) { $(".data-loading").hide(); var code = data.code; if (code != 0) { dangerBox(data.message); lock = false; return false; } lock = false; $('#form_modal').modal('hide') successBox('角色編輯成功.'); $('#btn_role_refresh').trigger('click'); } return false; }, error: function (e) { if (e.status == 404) { window.location = "../../404.html"; } else if (e.status == 500) { window.location = "../../500.html"; } } }); }); task.delay(500); return false; }; /** * 角色刪除 */ function onDelete() { if (lock) return false; lock = true; var ids = []; var rowList = dataGrid.bootstrapTable('getSelections'); var length = rowList.length; if (length == 0) { warningBox('請選擇刪除對象.'); lock = false; return false; } var flag = false; for (var i in rowList) { var row = rowList[i]; var createrId = row.createrId; if (userToken.id != createrId) { flag = true; } var id = row.id; ids.push(id); } if (flag) { warningBox('對不起,您無權刪除該角色.'); lock = false; return false; } var params = {}; params.ids = ids; deleteModal(ids); return false; }; /** * 刪除模態 */ function deleteModal(ids) { confirmBox('您肯定要刪除嗎?!', function (result) { if (result) { $('.data-loading').show(); $.ajax({ cache: false, type: 'POST', dataType: 'json', contentType: 'application/json;charset=utf-8', url: '../admin/role/delete', data: JSON.stringify(ids), timeout: 30000, success: function (data) { if (data) { $('.data-loading').hide(); var code = data.code; if (code != 0) { dangerBox(data.message); lock = false; return false; } lock = false; successBox('角色刪除成功.'); $('#btn_role_refresh').trigger('click'); } return false; }, error: function (e) { if (e.status == 404) { window.location = '../../404.html'; } else if (e.status == 500) { window.location = '../../500.html'; } } }); } else { lock = false; } }); return false; }; /** * 選擇模塊 */ function checkModule(moduleId) { $("input[name='fun_" + moduleId + "']").each(function () { if ($(this).is(":checked") == true) { $(this).prop("checked", false) } else { $(this).prop("checked", true); } }); }; /** * 選擇功能 */ function checkFun(moduleId) { var funLength = $("input[name='fun_" + moduleId + "']:checkbox:checked").length; if (funLength != 0) { $("input[name='mod_" + moduleId + "']").prop("checked", true); } else { $("input[name='mod_" + moduleId + "']").prop("checked", false); } }; /** * 選擇動做 */ function checkAction(funId) { var actLength = $("input[name='act_" + funId + "']:checkbox:checked").length; if (actLength != 0) { $("input[id='power_" + funId + "']").prop("checked", true); } else { $("input[id='power_" + funId + "']").prop("checked", false); } };
(4)業務控制器 RoleController.php
<?php /** * This is class RoleController * 角色控制器 * @author steven9801@163.com * @date 2015-11-19 * */ class RoleController extends BaseController { private $roleInfoService = null; private $userInfoService = null; private $moduleInfoService = null; private $roleModuleService = null; private $transactionalService = null; public function __construct() { if(is_null($this->userInfoService)) { $this->userInfoService = new UserInfoService; } if(is_null($this->roleInfoService)) { $this->roleInfoService = new RoleInfoService; } if(is_null($this->moduleInfoService)) { $this->moduleInfoService = new ModuleInfoService; } if(is_null($this->roleModuleService)) { $this->roleModuleService = new RoleModuleService; } if(is_null($this->transactionalService)) { $this->transactionalService = new TransactionalService; } } /** * 角色界面 */ public function index() { if (!Auth::check()) { return Redirect::to('admin/login'); } $moduleList = $this->moduleInfoService->selectModuleInfo(); if(!is_null($moduleList)) { $moduleList = $this->objectToTree($moduleList); } return View::make('backend.role',array('sys' => $this->getConfigInfo())) ->with('version',Str::random(6)) ->with('roleModuleList',$this->getRoleModuleInfo()) ->with('user',Auth::user()) ->with('moduleList',$moduleList); } /** * 角色列表 */ public function grid() { if (!Auth::check()) { return Redirect::to('admin/login'); } try { $roleInfo = (object)Input::all(); $userInfo = Auth::user(); $sortName = $roleInfo->sortName; $sortOrder = $roleInfo->sortOrder; $pageStart = $roleInfo->pageStart; $pageSize = $roleInfo->pageSize; $where = function($query) use($roleInfo,$userInfo) { if(isset($roleInfo->roleName)) { $query->where('role_name','like','%'.$roleInfo->roleName.'%'); } }; $total = $this->roleInfoService->getRoleInfoCount($where); $roleInfoList = $this->roleInfoService->searchRoleInfo($where,$sortName,$sortOrder,$pageStart,$pageSize); $entityGrid = null; if(!is_null($roleInfoList)&&$roleInfoList->count()>0) { foreach($roleInfoList as $roleModel) { $roleId = $roleModel->id; $where = function($query) use($roleId) { $query->where('role_id',$roleId); }; $roleModuleListModel = $this->roleModuleService->selectRoleModule($where); if(!is_null($roleModuleListModel)) { $roleModuleList = array(); foreach($roleModuleListModel as $roleModule) { $roleModuleList[] = $roleModule->moduleId; } $roleModel->roleModuleList = $roleModuleList; } } $entityGrid = $this->getEntityGrid($roleInfoList,$total); } else { $entityGrid = $this->getEntityGrid($roleInfoList); } $this->handlerResponseMessage($entityGrid); return $this->handlerResponseMessage($entityGrid); } catch(Exception $e) { Log::error($e->getMessage()); return $this->handlerFailMessage($e->getMessage()); } } /** * 角色新建 */ public function add() { if (!Auth::check()) { return Redirect::to('admin/login'); } try { $roleInfo = (object)Input::all(); $userInfo = Auth::user(); $roleName = $roleInfo->roleName; $where = function($query) use($roleName) { $query->where('role_name',$roleName); }; $roleInfoModel = $this->roleInfoService->getRoleInfo($where); if(!is_null($roleInfoModel)) { throw new Exception('角色名稱已存在.'); } $roleInfo->createrId = $userInfo->id; $result = $this->transactionalService->insertRoleInfo($roleInfo); if($result==0) { throw new Exception('角色新建失敗.'); } $this->logSuccess(); return $this->handlerSuccessMessage('../admin/role'); } catch(Exception $e) { $this->logFailed(); Log::error($e->getMessage()); return $this->handlerFailMessage($e->getMessage()); } } /** * 角色編輯 */ public function edit() { if (!Auth::check()) { return Redirect::to('admin/login'); } try { $roleInfo = (object)Input::all(); $userInfo = Auth::user(); $result = $this->transactionalService->updateRoleInfo($roleInfo); if($result==0) { throw new Exception('角色編輯失敗.'); } $this->logSuccess(); return $this->handlerSuccessMessage('../admin/role'); } catch(Exception $e) { $this->logFailed(); Log::error($e->getMessage()); return $this->handlerFailMessage($e->getMessage()); } } /** * 角色刪除 */ public function delete() { if (!Auth::check()) { return Redirect::to('admin/login'); } try { $ids = (array)Input::all(); $roleInfoList = $this->roleInfoService->selectRoleInfoByList($ids); if(is_null($roleInfoList)&&$roleInfoList->count()==0) { throw new Exception('角色刪除失敗.'); } $result = $this->transactionalService->deleteRoleInfo($roleInfoList); if($result==0) { throw new Exception('角色刪除失敗.'); } $this->logSuccess(); return $this->handlerSuccessMessage('../admin/role'); } catch(Exception $e) { $this->logFailed(); Log::error($e->getMessage()); return $this->handlerFailMessage($e->getMessage()); } } }
(5)業務實體層 RoleInfo.php
<?php /** * This is class RoleInfo * 角色實體類 * @author steven9801@163.com * @date 2015-11-19 */ class RoleInfo extends BaseModel { protected $table = 'tb_role_info'; protected $primaryKey = 'id'; protected $softDelete = false; protected $roleModuleList = null; }
(6)業務數據層 RoleInfoDataProvider.php
<?php /** * This is class RoleInfoDataProvider * 角色數據驅動類 * @author steven9801@163.com * @date 2015-11-19 */ class RoleInfoDataProvider extends BaseDataProvider { public function __construct() { parent::__construct(new RoleInfo); } public function insertRoleInfo($model) { $roleInfo = new RoleInfo; $roleInfo->roleName = isset($model->roleName)?$model->roleName:''; $roleInfo->roleMark = isset($model->roleMark)?$model->roleMark:''; $roleInfo->createrId = isset($model->createrId)?$model->createrId:0; return $roleInfo->save() ? $roleInfo -> id:0; } public function updateRoleInfo($model) { if(!($model->id)) { throw new Exception('參數id不能爲空.'); } $roleInfo = RoleInfo::find($model->id); if(is_null($roleInfo)) { throw new Exception('[ID='.$model->id. ']不存在或者已被刪除.'); } if(isset($model->roleName)) { $roleInfo->roleName = $model->roleName; } if(isset($model->roleMark)) { $roleInfo->roleMark = $model->roleMark; } if(isset($model->createrId)) { $roleInfo->createrId = $model->createrId; } return $roleInfo->save(); } public function clearRoleInfo() { $roleInfoList = RoleInfo::all(); if(is_null($roleInfoList)) { throw new Exception('記錄不存在或者已被刪除.'); } foreach($roleInfoList as $roleInfo) { $result = $roleInfo->delete(); if(!$result) { break; } } return $result; } public function deleteRoleInfo($roleInfo) { return $roleInfo->delete(); } public function deleteRoleInfoByList($ids) { return RoleInfo::whereIn('id', $ids)->delete(); } public function getRoleInfo($where) { if(is_null($where)) { return RoleInfo::first(); } return RoleInfo::where($where)->first(); } public function getRoleInfoCount($where) { if(is_null($where)) { return RoleInfo::count(); } return RoleInfo::where($where)->count(); } public function selectRoleInfo($where,$sortName,$sortOrder) { if(is_null($where)) { return RoleInfo::orderBy(snake_case($sortName),$sortOrder)->get(); } return RoleInfo::where($where)->orderBy(snake_case($sortName),$sortOrder)->get(); } public function selectRoleInfoByList($ids) { return RoleInfo::whereIn('id', $ids)->get(); } public function searchRoleInfo($where, $sortName, $sortOrder, $pageStart, $pageSize) { if(is_null($where)) { return RoleInfo::orderBy(snake_case($sortName),$sortOrder)->skip($pageStart)->take($pageSize)->get(); } return RoleInfo::where($where)->orderBy(snake_case($sortName),$sortOrder)->skip($pageStart)->take($pageSize)->get(); } }
(7)業務服務層 RoleInfoService.php
<?php /** * This is class RoleInfoService * 角色服務類 * @author steven9801@163.com * @date 2015-11-19 */ class RoleInfoService extends BaseService { private $roleInfoDataProvider = null; public function __construct() { if(is_null($this->roleInfoDataProvider)) { $this->roleInfoDataProvider = new RoleInfoDataProvider; } parent::__construct($this->roleInfoDataProvider); } public function insertRoleInfo($roleInfo) { $result = DB::transaction(function() use ($roleInfo) { return $this->roleInfoDataProvider->insertRoleInfo($roleInfo); }); return $result; } public function insertRoleInfoBatch($roleInfoList) { $result = DB::transaction(function() use ($roleInfoList) { $insertedCount = 0; $changed = 0; foreach($roleInfoList as $roleInfo) { $changed = $this->roleInfoDataProvider->insertRoleInfo($roleInfo); if ($changed < 1) { return 0; } $insertedCount++; } return $insertedCount; }); return $result; } public function updateRoleInfo($roleInfo) { $result = DB::transaction(function() use ($roleInfo) { return $this->roleInfoDataProvider->updateRoleInfo($roleInfo); }); return $result; } public function updateRoleInfoBatch($roleInfoList) { $result = DB::transaction(function() use ($roleInfoList) { $updatedCount = 0; $changed = 0; foreach($roleInfoList as $roleInfo) { $changed = $this->roleInfoDataProvider->updateRoleInfo($roleInfo); if ($changed < 1) { return 0; } $updatedCount++; } return $updatedCount; }); return $result; } public function clearRoleInfo() { $result = DB::transaction(function() use ($roleInfo) { return $this->roleInfoDataProvider->clearRoleInfo(); }); return $result; } public function deleteRoleInfo($roleInfo) { $result = DB::transaction(function() use ($roleInfo) { return $this->roleInfoDataProvider->deleteRoleInfo($roleInfo); }); return $result; } public function deleteRoleInfoByList($ids) { $result = DB::transaction(function() use ($ids) { return $this->roleInfoDataProvider->deleteRoleInfoByList($ids); }); return $result; } public function deleteRoleInfoBatch($roleInfoList) { $result = DB::transaction(function() use ($roleInfoList) { $deletedCount = 0; $changed = 0; foreach($roleInfoList as $roleInfo) { $changed = $this->roleInfoDataProvider->deleteRoleInfo($roleInfo); if ($changed < 1) { return 0; } $deletedCount++; } return $deletedCount; }); return $result; } public function getRoleInfo($where=null) { return $this->roleInfoDataProvider->getRoleInfo($where); } public function getRoleInfoCount($where=null) { return $this->roleInfoDataProvider->getRoleInfoCount($where); } public function selectRoleInfo($where=null,$sortName='id',$sortOrder='desc') { return $this->roleInfoDataProvider->selectRoleInfo($where,$sortName,$sortOrder); } public function selectRoleInfoByList($Ids) { return $this->roleInfoDataProvider->selectRoleInfoByList($Ids); } public function searchRoleInfo($where=null, $sortName='id', $sortOrder='desc', $pageStart=0, $pageSize=25) { return $this->roleInfoDataProvider->searchRoleInfo($where, $sortName, $sortOrder, $pageStart, $pageSize); } }
就這樣簡單整個業務表的CRUD結構清晰的完整的呈如今你面前啦。管中窺豹,真正擁有者會如獲至寶。
敬請期待下期:
spring mvc 實戰化項目之三板斧
asp.net mvc 實戰化項目之三板斧
感興趣的朋友掃下面的二維碼給點打賞吧!