## 知識點
1、思路分析
2、彈出彈框
3、彈出彈框顯示規則
[TOC]
## 一、思路分析
權限設置,是針對權限組,某個角色擁有哪些規則,每個規則都有一個單獨的ID
auth_group中的字段rules,規則id就保存在rules字段下面,中間用逗號隔開
點擊權限設置按鈕,彈出一個彈框,顯示所有的規則
## 二、彈出彈框
layer是一款近年來備受青睞的web彈層組件
官網:http://layer.layui.com/
### (一)模板鏈接
~~~
<a class="parentIframe" href="javascript:;" rel="{$vo.id}">權限設置</a>
{volist name="authrolelist" id="vo"}
<tr>
<td>{$vo.id}</td>
<td>{$vo.title}</td>
<td>{$vo.remark}</td>
<td>{$vo.status? '√' : '?'}</td>
<td>
<a class="parentIframe" href="javascript:;" rel="{$vo.id}">權限設置</a> |
<a href="{:url('index',['id'=>$vo.id,'tab'=>3])}">編輯</a> |
<a name="delete" href="{:url('delete',['id'=>$vo.id])}">刪除</a>
</td>
</tr>
{/volist}
~~~
### (二)事件響應
~~~
<script>
$('.parentIframe').on('click',function(){
layer.open({
type: 2,
title: '權限設置',
area: ['500px', '550px'],
fixed: false, //不固定
maxmin: true,
content: 'authset'
});
});
</script>
~~~
### (三)新建authset文件
位置:application\admin\view\authrole\authset.html
### (四)后臺處理
~~~
public function authset() {
return view();
}
~~~
## 三、彈出彈框顯示規則
整合插件jstree
### (一)簡單實例
#### 1、引入類庫
~~~
<link href="__ADMIN__/css/bootstrap.min14ed.css?v=3.3.6" rel="stylesheet">
<link href="__ADMIN__/css/plugins/jsTree/style.min.css" rel="stylesheet">
<link href="__ADMIN__/css/animate.min.css" rel="stylesheet">
<link href="__ADMIN__/css/style.min862f.css?v=4.1.0" rel="stylesheet">
<!--[if lt IE 9]><script src="https://static.jstree.com/3.3.4/assets/html5.js"></script><![endif]-->
<link rel="stylesheet" href="https://static.jstree.com/3.3.4/assets/dist/themes/default/style.min.css">
<!--[if lt IE 9]><script src="https://static.jstree.com/3.3.4/assets/respond.js"></script><![endif]-->
<script src="__ADMIN__/js/jquery.min.js?v=2.1.4"></script>
<script src="__ADMIN__/js/bootstrap.min.js?v=3.3.6"></script>
<script src="__ADMIN__/js/content.min.js?v=1.0.0"></script>
<script src="__ADMIN__/js/plugins/jsTree/jstree.min.js"></script>
~~~
#### 2、模板代碼
~~~
<div id="jstree"></div>
~~~
#### 3、事件響應
~~~
<script>
$('.parentIframe').on('click',function(){
var role_id = $(this).attr('rel');
layer.open({
type: 2,
title: '權限設置',
area: ['500px', '550px'],
fixed: false, //不固定
maxmin: true,
content: 'authset/id/' + role_id
});
});
</script>
~~~
### (二)動態獲取信息
#### 1、響應事件
~~~
<script>
$(function() {
$('#jstree').jstree({
"plugins" : [ "checkbox" ],
"checkbox" : {
"keep_selected_style" : false
},
"core" : {
"data" : {$json}
}
});
});
</script>
~~~
#### 2、獲取規則
~~~
public function authset() {
// 獲取規則
$result = Db::name('auth_rule')->order('listorder')->select();
$json = array();
foreach ($result as $value) {
$data = array(
'id' => $value['id'],
'parent' => $value['pid']==0 ? '#' : $value['pid'],
'text' => $value['title'],
);
$json[] = $data;
}
$this->assign('json', json_encode($json));
return view();
}
~~~
#### 3、模板表單
~~~
<form method="post" class="form-horizontal" action="{:url('authset')}" data-type="ajax" style="padding:30px">
<input type="hidden" name="id" value="{:input('id',0)}">
<input type="text" name="rules">
<div id="jstree"></div>
<div class="form-group" style="margin: 30px 80px">
<button class="btn btn-primary" type="submit">提交</button>
</div>
</form>
~~~
#### 4、默認全部展開
~~~
public function authset() {
if(request()->isPost()){
$data = input('post.');
Db::name('auth_group')->strict(false)->update($data);
return success('權限設置成功!',url('index',['tab'=>1]));
}else{
// 獲取規則
$result = Db::name('auth_rule')->order('listorder')->select();
$json = array();
foreach ($result as $value) {
$data = array(
'id' => $value['id'],
'parent' => $value['pid']==0 ? '#' : $value['pid'],
'text' => $value['title'],
'state' => ['opened' => true] //默認全部展開
);
$json[] = $data;
}
$this->assign('json', json_encode($json));
return view();
}
}
~~~
#### 5、選中ID
~~~
表單
<input type="hidden" id="event_result" name="rules">
事件響應
$(function() {
$('#jstree').jstree({
"plugins" : [ "checkbox" ],
"checkbox" : {
"keep_selected_style" : false
},
"core" : {
"data" : {$json}
}
})
.on('changed.jstree', function (e, data) {
var i, j, r = [];
for(i = 0, j = data.selected.length; i < j; i++) {
r.push(data.instance.get_node(data.selected[i]).id);
}
$('#event_result').val(r.join(','));
});
});
</script>
~~~
#### 6、提交數據后臺保存數據庫
~~~
$data = input('post.');
Db::name('auth_group')->strict(false)->update($data);
return success('權限設置成功!',url('index',['tab'=>1]));
~~~
#### 7、打開權限默認勾選
~~~
'state' => ['opened' => true, 'selected' => in_array($value['id'],$rules)? true : false]
public function authset($id = 0) {
if(request()->isPost()){
$data = input('post.');
Db::name('auth_group')->strict(false)->update($data);
return success('權限設置成功!',url('index',['tab'=>1]));
}else{
// 獲取當前角色所有規則
$rules =Db::name('auth_group')->where('id',$id)->value('rules');
//規則轉數組
$rules = explode(',',$rules);
// 獲取規則
$result = Db::name('auth_rule')->order('listorder')->select();
$json = array();
foreach ($result as $value) {
$data = array(
'id' => $value['id'],
'parent' => $value['pid']==0 ? '#' : $value['pid'],
'text' => $value['title'],
'state' => ['opened' => true, 'selected' => in_array($value['id'],$rules)? true : false]
);
$json[] = $data;
}
$this->assign('json', json_encode($json));
return view();
}
}
~~~
#### 8、彈框處理
~~~
<script src="__ADMIN__/js/plugins/layer/layer.min.js"></script>
<script src="__ADMIN__/js/layer_hplus.js"></script>
~~~
放文件最底部
#### 9、關閉彈框返回
重新定義一個跳轉函數successIframe()
自定義successIframe助手函數
位置:application\common.php
~~~
function successIframe($msg = '成功', $url = '') {
$data['status'] = 201;
$data['msg'] = $msg;
return json($data);
}
~~~
修改layer_hplus.js
~~~
$(document).on('submit','form[data-type=ajax]',function(){
//獲取數據
var url = $(this).attr('action');
var data = $(this).serializeArray();//序列化表單元素
//彈出詢問框
layer.confirm('您確定提交處理嗎?',{icon:3, title:'提示'},function(index){
//異步提交
$.ajax({
type: "POST",
dataType:"json",
url:url,
data:data,
success:function(obj){
var icon_num = (obj.status==202) ? 2 : 1;
if(obj.status==200 || obj.status==202){
layer.open({
content: obj.msg,
btn: ['確定'],
shade: 0.1,
icon: icon_num,
yes: function(index, layero){
if(obj.url){
location.href = obj.url; //跳轉指定地址
}else{
layer.close(index);
}
},
cancel: function(){
if(obj.url){
location.href = obj.url; //跳轉指定地址
}else{
layer.close();
}
},
});
}else if(obj.status==201){
layer.open({
content: obj.msg,
btn: ['確定'],
shade: 0.1,
icon: icon_num,
yes: function(index, layero){
var index = parent.layer.getFrameIndex(window.name);
parent.layer.close(index);
},
cancel: function(){
layer.close();
},
});
}
},
error:function(data){
layer.alert('網絡故障!');
}
});
});
return false;
});
~~~
- Layer無刷新不跳轉彈框提示信息
- 整合ThinkPHP+實用代碼
- TP整合Layer插件實現無刷新
- 自定義助手函數
- 添加信息失敗后不跳轉
- 三種無限級分類
- TP常用代碼
- 自定義公共函數
- TP模型管理專題
- TP模型管理之添加模型
- sfox_newmodel.sql
- TP模型管理之刪除模型
- TP模型管理之編輯模型
- TP模型管理之字段添加
- sfox_newmodel.sql_edit
- layer_hplus.js_edit
- TP模型管理之字段刪除
- TP模型管理之字段編輯
- TP模型管理之預覽模型
- TP模型管理之公共函數
- layer_hplus.js_修訂一
- TP模型管理之預覽模型靜態頁
- 后臺內容管理系統
- 分類樹顯示
- 內容列表顯示
- 信息發布
- 編輯信息
- layer_hplus.js
- myJs第一版
- myJs第二版
- myJs第三版
- myJs第四版
- TP5插件用法
- Datatables
- WebUploader
- bootstrap-fileinput
- UEditor
- 簡單調用
- 路徑問題
- 跨域多圖上傳
- 跨域單圖上傳
- UEditor圖片跨域上傳解決方案
- 定制工具欄圖標
- ajaxFileUpload
- LayUI
- 圖片上傳
- layui分頁
- 搜索頁
- 搜索優化及刪除
- Uploadify
- TP5前端應用
- 靜態首頁
- 前臺首頁功能實現
- 自定義標簽庫
- 前臺模板繼承應用
- 首頁自定義標簽改進
- 文章內容頁
- 自定義標簽改進
- 自定義標簽修正
- 圖片等比例自動縮放
- 后臺權限管理
- 角色管理
- 規則管理
- 權限設置
- 會員管理
- 權限管理
- 前臺登錄注冊功能
- 注冊登錄
- 阿里大于手機注冊
- 阿里大于升級阿里云短信服務
- 自動登錄完成
- PHP異位或加密實現自動登陸
- 微信開發
- 分享接口
- 靜態頁面實現微信分享
- 動態頁微信分享
- 頁面靜態化
- 1-全站靜態化前期配置
- 2-鏈接地址靜態化
- TP5常用片段代碼
- 加載靜態資源路徑與常量
- thinkphp5預定義常量
- 刪除某文件夾的內容
- 解壓插件包
- 異步提交插件
- 其他功能
- 背景音樂
- 手機訪問PC網站自動跳轉到手機網站代碼
- 手機微信音樂MP3播放器
- 后盾之網頁背景音樂
- 播放器寬度自適應
- 前臺首頁數據調用
- 視頻列表
- 搜索分頁
- H5解決蘋果(IOS)不能自動播放音樂
- 清空緩存
- 文件處理常識
- 刪除路徑下的所有文件夾和文件
- 一鍵清空緩存
- 評論留言
- 格式化時間
- 替換微博內容的URL地址@用戶與表情
- PHP正則理解
- jQuery評論插件
- TP空操作
- TP路由
- 跨域訪問
- 設置請其頭允許跨域請求
- 模板前臺判斷手機訪問跳轉手機網址代碼
- PHP遍歷一個文件夾下所有文件和子文件夾
- PHP獲取視頻的第一幀與時長
- TP5數據庫
- 鏈式操作原理
- update替換字段部分內容
- 后臺開發
- 后臺登錄頁居中顯示
- TP5自帶驗證碼
- JS & JQuery專題
- 二級城市聯動菜單
- 模板引擎
- 混合模板編譯
- 黃永成TP微博開發
- 消息推送
- memcache安裝
- 插件開發
- 插件介紹
- 插件鉤子
- 淺談初步理解鉤子
- 插件鉤子(hooks)分析
- 插件鉤子簡單理解
- 控制器調用插件
- 鉤子通用處理函數
- 插件基類代碼
- 插件測試代碼
- 淺談鉤子與插件
- 技術綜合
- 常用代碼
- PHP
- 56個PHP開發常用代碼片段(上)
- 56個PHP 開發常用代碼片段(中)
- 56個PHP 開發常用代碼片段(下)
- sublime text安裝自動補全注釋的插件
- 影音視頻開發
- 視頻
- H5視頻直播掃盲
- 音樂
- 語音
- PHP實現語音播報功能
- MUI
- 窗體操作