關(guān)于Laravel-admin的基礎(chǔ)用法總結(jié)和自定義model詳解
總結(jié)laravel-admin展示用到的基本方法
基礎(chǔ)用法
自定義model
當(dāng)列表數(shù)據(jù)獲取有特定條件或自己寫ORM方法時可以用到,支持排序
$grid->model()->select('id','name')->where('status',1)->groupBy('project_id');
$grid->model()->select('id','name')->where('status',1)->groupBy('project_id');
//結(jié)合having 查出名字重復(fù)的
$grid->model()->select('name_en')->groupBy('name_en')->havingRaw('count(name_en)>1')
//嵌套子查詢 查出名字重復(fù)的全部信息
$grid->model()->select('id','name_en')->whereIn('name_en',Project::select('name_en')->groupBy('name_en')->havingRaw('count(name_en)>1'))->orderBy('name_en');
模型數(shù)據(jù)獲取
第一列顯示id字段,并將這一列設(shè)置為可排序列
$grid->id('ID')->sortable();
獲取單列數(shù)據(jù)的方法
$grid->name_cn('名稱');
注:name_cn為與數(shù)據(jù)庫對應(yīng)的字段名
$grid->column('name_cn','名稱');
判斷type來顯示不同的狀態(tài)
$grid->column('type','類型?')->display(function ($type) {
return $type == 1 ? '111' : '222';
});
where條件
$grid->model()->where('type', 0);
三個時間的顯示
// 下面為三個時間字段的列顯示 $grid->release_at(); $grid->created_at(); $grid->updated_at();
篩選框控制方法
基本方法
//filter($callback)方法用來設(shè)置表格的簡單搜索框
$grid->filter(function ($filter) {
//1.時間段篩選 設(shè)置created_at字段的范圍查詢
$filter->between('created_at', '篩選時間')->datetime();
//2.字段模糊查詢 like = '% %'
$filter->like('name', '姓名');
//3.字段equal 篩選
$filter->equal('status', '狀態(tài)')->select([0 => '下線', 1 => '上線']);
//4.去掉默認(rèn)的ID搜索
$filter->disableIdFilter();
//5.
});
按鈕控制
禁用導(dǎo)出
$grid->disableExport();
禁用新增
$grid->disableCreateButton();
禁用行選擇checkbox
$grid->disableRowSelector();
去掉重置 [from]
$form->disableReset();
關(guān)閉默認(rèn)行操作
$grid->actions(function ($actions) {
//關(guān)閉刪除
$actions->disableDelete();
//關(guān)閉編輯
$actions->disableEdit();
//自定義操作按鈕
$actions->append('<button type="button" class="btn btn-danger noShow" data-id="' . $actions->getKey() . '" >隱藏</button>');
});
關(guān)閉批量刪除
$grid->tools(function ($tools) {
//關(guān)閉批量刪除
$tools->batch(function ($batch) {
$batch->disableDelete();
});
});
FORM表單提交
禁用重置按鈕
$form->disableReset();
文本輸入框
//默認(rèn)展示$data['name']的值,新接收的值存儲user表name字段
$form->text('user.name', '名稱')->default($data['name']);
上傳圖片/文件
$form->image('user.logo', 'logo')
#隨機(jī)文件名
->uniqueName()
#驗證文件格式('mimes:doc,docx,xlsx');
->rules('mimes:png')
#輸入框下邊的help提示語
->help($str);
表單提交url
$form->url('user.website', '官網(wǎng)')
#默認(rèn)填充url 傳參
->default($url)
#提示的url
->help('eg: http://www.aware.bi');
表單提交下拉框
#下拉框展示$message提示語
$form->multipleSelect('project.tags1', $message)
#下拉框數(shù)據(jù)
->options($tags['children']);
select下來
$types = array('0'=>'教育','1'=>'醫(yī)療');
$form->select('type', '類型')->options($types);
laravel SQL取值
$users = User::all()->pluck('name', 'id')->toArray();
表單輸入HTML editor編輯器
$form->editor('detail', '詳細(xì)介紹');
單選按鈕 樣式轉(zhuǎn)換
$states = [
'on' => ['value' => 1, 'text' => '上線', 'color' => 'success'],
'off' => ['value' => 0, 'text' => '下線', 'color' => 'danger'],
];
$form->switch('status', '上/下線')->states($states);
隱藏域
$form->hidden('is_in');
保存數(shù)據(jù)的回調(diào)
$form->saving(function (Form $form) {
#指定值為固定1
$form->is_in = 1;
#驗證值是夠有重復(fù)
if($from->nick_name !== $form->model()->email && User::where('email',$form->email)->value('id')){
#錯誤信息提示
$error = new MessageBag(['title'=>'提示','message'=>'郵箱已存在!']);
return back()->withInput()->with(compact('error'));
}
});
自定義按鈕操作
我們先自定義了一個隱藏按鈕
$grid->actions(function ($actions) {
//自定義操作按鈕
$actions->append('<button type="button" class="btn btn-danger noShow"
data-id="' . $actions->getKey() . '" >隱藏</button>');
//當(dāng)前數(shù)據(jù)的ID
});
在controller寫JS文件把執(zhí)行JS渲染到模板
$js = <<<EOD
<script>
//隱藏的點擊事件
$(document).on('click', '.noShow', function() {
//獲取的ID
var id = $(this).data('id');
console.log(id);
swal({
title: "確認(rèn)隱藏?",
type: "warning",
showCancelButton: true,
confirmButtonColor: "#DD6B55",
confirmButtonText: "確認(rèn)",
closeOnConfirm: false,
cancelButtonText: "取消"
},
function(){
$.ajax({
method: 'post',
url: '/admin/articles/hidden',
data: {
//文章ID
id:id,
//post請求token
_token:LA.token,
},
success: function (data) {
$.pjax.reload('#pjax-container');
if (typeof data === 'object') {
if (data.status == 1) {
swal(data.msg, '', 'success');
} else {
swal(data.msg, '', 'error');
}
}
}
})
}
)
});
</script>
EOD;
//傳遞到頁面
$content->body($js);
//執(zhí)行你的model
$content->body();
以上這篇關(guān)于Laravel-admin的基礎(chǔ)用法總結(jié)和自定義model詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
去掉destoon資訊內(nèi)容頁keywords關(guān)鍵字自帶的文章標(biāo)題的方法
這篇文章主要介紹了去掉destoon資訊內(nèi)容頁keywords關(guān)鍵字自帶的文章標(biāo)題的方法,有一定的實用價值,需要的朋友可以參考下2014-08-08
網(wǎng)頁游戲開發(fā)入門教程三(簡單程序應(yīng)用)
用哪種組合,真的不重要。重要的是時間和成本。復(fù)雜的地方在數(shù)據(jù)的交互和完善,而不在技術(shù)或效果的實現(xiàn)。2009-11-11
Joomla實現(xiàn)組件中彈出一個模式(modal)窗口的方法
這篇文章主要介紹了Joomla實現(xiàn)組件中彈出一個模式(modal)窗口的方法,列舉了2種常用的Joomla彈出模式窗口的技巧供大家對比參考,需要的朋友可以參考下2016-05-05
利用php+mysql來做一個功能強(qiáng)大的在線計算器
有天在努力的搜索計算器,發(fā)現(xiàn)都是JavaScript,而且要一個個地點擊,并且不能記錄,輸入計算式子時容易出錯,于是就想了想該怎樣才能讓它好用點呢,能夠用鍵盤直接輸入。2010-10-10
Thinkphp5框架實現(xiàn)圖片、音頻和視頻文件的上傳功能詳解
這篇文章主要介紹了Thinkphp5框架實現(xiàn)圖片、音頻和視頻文件的上傳功能,結(jié)合實例形式分析了thinkPHP5文件上傳的原理、操作步驟、實現(xiàn)方法及相關(guān)注意事項,需要的朋友可以參考下2019-08-08

