本文實(shí)例講述了ThinkPHP55.1框架關(guān)聯(lián)模型分頁(yè)操作。分享給大家供大家參考,具體如下:
利用數(shù)據(jù)庫(kù)的分頁(yè)通常比較簡(jiǎn)單,但在實(shí)際項(xiàng)目中,我們往往需要處理復(fù)雜的數(shù)據(jù),例如多表操作,這時(shí)候我們就需要利用模型層的關(guān)聯(lián)操作得到最終想要的數(shù)據(jù),而這些數(shù)據(jù)我們其實(shí)也是可以利用ThinkPHP55.1內(nèi)置的分頁(yè)引擎進(jìn)行分頁(yè)的。
賣(mài)的車(chē)輛我們稱(chēng)之為車(chē)源,車(chē)源和車(chē)主之間是多對(duì)一關(guān)系(車(chē)主可以有多輛車(chē),一輛車(chē)只屬于一個(gè)車(chē)主);車(chē)源和車(chē)輛圖片之間是一對(duì)多關(guān)系(一輛車(chē)有多個(gè)圖片,一個(gè)圖片只屬于一輛車(chē));車(chē)輛還有自定義屬性,它們之間是多對(duì)多關(guān)系,車(chē)輛的級(jí)別在車(chē)源表是個(gè)數(shù)字,具體名稱(chēng)需要到級(jí)別表獲取。。。??梢钥闯觯@塊是非常復(fù)雜的,完全使用數(shù)據(jù)庫(kù)操作會(huì)非常復(fù)雜,所以我們選擇使用模型層進(jìn)行處理。
首先建立模型之間的關(guān)系:
public function selfattribute()
{
return $this->belongsToMany("Selfattribute",'cars_selfattribute','selfattribute_id','cars_id');
}
public function carsimg()
{
return $this->hasMany('Carsimg');
}
public function member()
{
return $this->belongsTo('\app\index\model\Member');
}
同時(shí)對(duì)應(yīng)的模型也要建立對(duì)應(yīng)的方法。
在控制器層寫(xiě)方法:
public function lst()
{
$cars_model = model("Cars");
$cars_list = $cars_model->getCarsList();
$this->assign("cars_list",$cars_list);
// dump($cars_list);
return view();
}
其中g(shù)etCarsList()方法在模型層中實(shí)現(xiàn):
public function getCarsList()
{
$cars_list = Cars::paginate(2)->each(function($value,$key){
$level_find = db("level")->where('id',$value['level'])->value('name');
$value['level_name'] = $level_find;
$value->carsimg;
$value->member;
$value->selfattribute;
});
return $cars_list;
}
模板上寫(xiě)法同普通分頁(yè):
div class="ibox-content">
table class="table table-bordered">
thead>
tr>
th>ID/th>
th>名稱(chēng)/th>
th>車(chē)主/th>
th>狀態(tài)/th>
th>操作/th>
/tr>
/thead>
tbody>
{volist name="cars_list" id="vo"}
tr>
td>{$vo.id}/td>
td>a href="{:url('index/cars/carsdetails',array('id'=>$vo.id))}" rel="external nofollow" >{$vo.full_name}/a>/td>
td>{$vo.member.member_name}/td>
td>
{switch $vo.status}
{case 1}上架{/case}
{case 0}下架{/case}
{case -1}已售{/case}
{default /}未審核
{/switch}
/td>
td>
div class="btn-group open">
button data-toggle="dropdown" class="btn btn-primary dropdown-toggle" aria-expanded="true">操作 span class="caret">/span>
/button>
ul class="dropdown-menu">
li>a href="">修改/a>
/li>
li>a href="">刪除/a>
/li>
/ul>
/div>
/td>
/tr>
{/volist}
/tbody>
/table>
{$cars_list|raw}
/div>

更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《ThinkPHP入門(mén)教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《codeigniter入門(mén)教程》、《CI(CodeIgniter)框架進(jìn)階教程》、《Zend FrameWork框架入門(mén)教程》及《PHP模板技術(shù)總結(jié)》。
希望本文所述對(duì)大家基于ThinkPHP框架的PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- ThinkPHP5.1+Ajax實(shí)現(xiàn)的無(wú)刷新分頁(yè)功能示例
- thinkphp5框架前后端分離項(xiàng)目實(shí)現(xiàn)分頁(yè)功能的方法分析
- thinkphp5+layui實(shí)現(xiàn)的分頁(yè)樣式示例
- thinkPHP5框架分頁(yè)樣式類(lèi)完整示例
- thinkPHP5框架實(shí)現(xiàn)基于ajax的分頁(yè)功能示例
- thinkPHP5分頁(yè)功能實(shí)現(xiàn)方法分析
- ThinkPHP5分頁(yè)paginate代碼實(shí)例解析