在模板中使用标签查询数据
Jun 07, 2016 am 11:39 AM新手练手,欢迎吐槽<?php <br />
<br>
/**<br>
* 通用自定义定义标签<br>
* 用法:<br>
* 1:载入<br>
* <taglib></taglib><br>
* 2:调用<br>
* <list><br>
* {$v.id} -- {$v.name}<br><br>
* </list><br>
* 说明:<br>
* 1.可以直接在标签上面写sql属性<br>
* 2.限制查询条数请用 limit属性<br>
* 3.要数据分页请用page属性,可传2个参数,用逗号分隔,前一个参数当前页码,后一个参数每页查询几条<br>
* 4.显示分页请在视图页面输出 {$pageStr}<br>
* 5.调用模型的方法 用 method="getOne(1,2,3)" 【引号里面直接调用方法】<br>
*/<br>
<br>
namespace Think\Template\TagLib;<br>
<br>
use Think\Template\TagLib;<br>
<br>
class Lx extends TagLib<br>
{<br>
<br>
protected $tags = array(<br>
'list' => array('attr' => 'table,order,limit,where,join,field,page,relation,method,cache,dump,sql', 'close' => 1),<br>
);<br>
<br>
public function _list($attr, $content)<br>
{<br>
$defaultAttr = explode(',', $this->tags['list']['attr']);<br>
$vars = array();<br>
foreach ($defaultAttr as $v) {<br>
if ($attr[$v]) {<br>
$vars[$v] = $attr[$v];<br>
}<br>
}<br>
if (!isset($vars['table']) || empty($vars['table'])) {<br>
return false;<br>
}<br>
//是用模型中的特定方法还是select<br>
if (isset($vars['method'])) {<br>
$select = '->' . $vars['method'];<br>
} else {<br>
$select = "->select()";<br>
}<br>
//limit and page<br>
$limit = '';<br>
<br>
if (!isset($vars['page'])) {<br>
if (isset($vars['limit'])) {<br>
$limit = '->limit("' . $vars['limit'] . '")';<br>
}<br>
} else {<br>
$limit = '->page("$page,$rows")';<br>
}<br>
//dump 调试<br>
$dump = '';<br>
if (isset($vars['dump']) && $vars['dump'] == "true") {<br>
$dump = '<?php dump($data) ?>';<br>
}<br>
//getLastSql 调试<br>
$lastSql = '';<br>
if (isset($vars['sql']) && $vars['sql'] == "true") {<br>
$lastSql = ' echo "<br>" . M()->getLastSql(); ';<br>
}<br>
unset($vars['page'], $vars['limit'], $vars['method'], $vars['dump'], $vars['sql']);<br>
$tmpStr = '';<br>
$where = '';<br>
$join = '';<br>
foreach ($vars as $k => $v) {<br>
if ($k == 'table') {<br>
continue;<br>
}<br>
if ($k == 'where') {<br>
$where = $v;<br>
}<br>
if ($k == 'join') {<br>
$join = $v;<br>
}<br>
$tmpStr .= '->' . $k . '("' . $v . '")';<br>
}<br>
$str = '<?php <br />
$page = I("p", false) ? I("p") : I("page");<br>
$page = empty($page) ? 1 : $page;<br>
$rows = I("rows", 15);<br>
$table = ' . ucfirst($vars['table']) . ';<br>
$data = D("$table")' . $tmpStr . $limit . $select . ';<br>
foreach($data as $k=>$v): ?>';<br>
$str .= $content;<br>
$str .= '<?php <br />
if(!is_array($v)){<br>
break ;<br>
}<br>
endforeach;<br>
'.$lastSql.'<br>
$total = M("$table")->where("' . $where . '")->join("' . $join . '")->count();<br>
$Page = new \Think\Page($total,$rows);<br>
$pageStr = $Page->show();<br>
?>';<br>
$str .= $dump;<br>
return $str;<br>
}<br>
<br>
<br>
}
AD:真正免费,域名+虚机+企业邮箱=0元

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Découvrez des exemples de code d'introduction à la programmation Python.

Comment utiliser PHP pour écrire le code de la fonction de gestion des stocks dans le système de gestion des stocks

Variables PHP en action : 10 exemples concrets d'utilisation

Java implémente un code de tri à bulles simple

Exemples de programmation en langage Go : exemples de code dans le développement Web

Guide d'interconnexion Huawei Cloud Edge Computing : exemples de code Java pour implémenter rapidement des interfaces

Du débutant au compétent : implémentation de code de structures de données couramment utilisées en langage Go

Conseils et exemples : Apprenez à implémenter l'algorithme de tri par sélection en Java
