目录
- 【ThinkPHP版本查询】
- 模板获取get参数
- 【循环嵌套标签】
- 模板循环标签
- {volist}{/volist}标签遍历
- {foreach}{/foreach}标签遍历
- 方法一
- 方法二
- {for}{/for}标签循环
- 【多个查询条件判断】非常实用
- 【单选框条件判断】
- 【模板中三层循环】
- 【未定义变量】{$catinfo.catname ?''}
- 获取单个字段值
- 【对象转数组】
- 【接收表单单个变量值】
- 【接收表单数组】
- 【接收链接数据】
- 【模型中新增数据】
- 【控制器中新增数据】
- 【引用模型别名】
- 【助手函数】
- 【静态方法调用】
- 【判断第三层分类下不能勾选子分类条件】
- 只要判断上级分类是第二层,就说明新添加分类为第三层,则不能勾选子分类选项
- 【单选框和复选框默认值】
- 【插入数据调整信息:修改器】
- 【读取磁盘文件】
- 【获取模板文件名】
- 【原生态删除数据表】
- 【原生态重命名数据表】
- 【原生态更改数据表某字段值】
- 【原生态修改数据表字段名称】
- 【原生态添加数据表字段名称】
- 【insert into table 插入多条数据】
- 【转数组格式】
- 模型专题
- 字符串查询(预处理机制)
- 【多个条件或判断】whereOr()
- 【多个条件或判断】where()
- 前台指定调用条数
- 奇偶循环调用
- 自动切换
- 1、前端模板
- 2、JS功能实现
- 加红关键字
【ThinkPHP版本查询】
dump(THINK_VERSION);
模板获取get参数
{$Think.get.pageNumber}
或者
$Request.param.name(参数名)
【循环嵌套标签】
<select class="form-control m-b" name="parentid">
<option value="0" selected>〓 作为顶级分类 〓</option>
{volist name='catone' id='vo'}
<option value="{$vo.id}" {if condition="input('parentid',0) eq $vo.id"}selected{/if}>{$vo.catname}</option>
{/volist}
</select>
模板循环标签
{volist}{/volist}标签遍历
【offset 开始遍历的地方】
【length 遍历的长度,循环的次数】
【mod 与当前数取余】
【empty 为空时显示】
【key 循环的次数】
<h1>这是view/index/index.html</h1>
{volist name="list" id="vo" offset="0" length="3" mod="2" empty="这里没有数据" key ='s'}
<p>{$mod}:{$s}:{$vo.name}</p>
{/volist}
{foreach}{/foreach}标签遍历
方法一
{foreach $list as $vo}
<p>{$vo.name}:{$vo.email}</p>
{/foreach}
方法二
{foreach name="list" as item="vo"}
<p>{$key} : {$vo.name} : {$vo.email}</p> 【$key 数组的下标】
{/foreach}
{for}{/for}标签循环
<body>
{for start="1" end="10" step="2" name="i"} 【start 相当于for循环中的$i=1】【end 相当于for循环中的$i<10】【strp 步进值】【name 默认为i,对应$i】
<p>{$i}</p>
{/for}
</body>
【多个查询条件判断】非常实用
// 检查分类名称和分类目录是否重名
$count_one = Db::name('category')->where('id','<>',$id)->where('catname',input('post.catname'))->count();
$count_two = Db::name('category')->where('id','<>',$id)->where('catdir',input('post.catdir'))->count();
if($count_one){
return error('分类名称重名!');
}else if($count_two){
return error('分类目录重名!');
}
【单选框条件判断】
<!--IF判断或者三元运算符(更简单,推荐)-->
<!--注意:三元运算条件判断只能用==,不能用eq(不能解析)-->
<!--($catinfo.isend == 1) ? 'checked' : '' 可以简写成:$catinfo.isend ? 'checked' : ''-->
<!--开启:-->
<input type="radio" value="1" name="ismenu" {$catinfo.ismenu ? 'checked' : ''}>
<!--隐藏:-->
<input type="radio" value="0" name="ismenu" {$catinfo.ismenu ? '' : 'checked'}>
【模板中三层循环】
{volist name="menu" id="vo"}
<li>
<a href="#" rel="external nofollow" ><i class="fa {$vo.icon}"></i> <span class="nav-label">{$vo.name}</span><span class="fa arrow"></span></a>
{eq name="vo.child" value="1"}
<ul class="nav nav-second-level">
{volist name="vo.son" id="voson"}
<li>
<a {eq name="voson.child" value="0"}class="J_menuItem"{/eq} href="{if condition='voson.child eq 1'}#{else /}{:url($voson.module.'/'.$voson.controller.'/'.$voson.action)}{/if}" rel="external nofollow" >{$voson.name} {eq name="voson.child" value="1"}<span class="fa arrow"></span>{/eq}</a>
{eq name="voson.child" value="1"}
<ul class="nav nav-third-level">
{volist name="voson.son" id="voend"}
<li><a class="J_menuItem" href="{:url($voend.module.'/'.$voend.controller.'/'.$voend.action)}" rel="external nofollow" >{$voend.name}</a></li>
{/volist}
</ul>
{/eq}
</li>
{/volist}
</ul>
{/eq}
</li>
{/volist}
【未定义变量】{$catinfo.catname ?''}
// 设置异常错误报错级别,关闭notice错误
error_reporting(E_ALL ^ E_NOTICE);
获取单个字段值
想直接获取单个字段值,弄了半天,tp5的getField()方法变了,具体如下:
TP5中的getField():拆分为value和column了
例子:
••• where("id = 1")->value("title"); 输出:(string) title
••• where("id = 1")->column("title"); 输出:(array)
【对象转数组】
$this->toArray();
【接收表单单个变量值】
input('post.tab');
【接收表单数组】
input('post.order/a');
【接收链接数据】
input('parentid',0)
【模型中新增数据】
save()
【控制器中新增数据】
insert()
【引用模型别名】
use app\admin\model\Category as CategoryModel;
【助手函数】
用助手函数Db,可以不用引用命名空间
【静态方法调用】
外部用类名::方法名,内部用self::方法名
【判断第三层分类下不能勾选子分类条件】
只要判断上级分类是第二层,就说明新添加分类为第三层,则不能勾选子分类选项
$parentid = Db::name('menu')->where('id',input('post.parentid'))->value('parentid');
if($parentid && input('post.child')){
return error('不能勾选拥有子菜单项!');
}
【单选框和复选框默认值】
前台变量如果值为0,提交则没有该变量,存入数据库则为默认值。解决方法有二:
方法一:修改数据表的默认值为0
方法二:控制器中判断,判断提交数据中是否有该变量,没有则设置该变量值为0
【插入数据调整信息:修改器】
protected $insert = ['addtime'];
//addtime修改器
protected function setAddtimeAttr($value){
return date('Y-m-d H:i:s');
}
【读取磁盘文件】
const newModelSql = './data/sfox_newmodel.sql';
$newModelSql = file_get_contents(self::newModelSql);
【获取模板文件名】
$handle = opendir('../template/default/temp/');
while ($file = readdir($handle)) {
if ($file != '.' && $file != '..') {
$files[]['name'] = $file;
}
}
【原生态删除数据表】
$dbPrefix = config('database.prefix');
Db::execute("DROP TABLE `{$dbPrefix}{$tablename}`;");
【原生态重命名数据表】
$dbPrefix = config('database.prefix');
Db::execute("RENAME TABLE `{$dbPrefix}{$oldTableName}` TO `{$dbPrefix}{$newTableName}` ;");
【原生态更改数据表某字段值】
UPDATE tp_models_field SET issystem=0 WHERE modelid=35;
【原生态修改数据表字段名称】
ALTER TABLE `ps_test` DROP COLUMN `{$info['field']}` ;
【原生态添加数据表字段名称】
ALTER TABLE `ps_test` ADD `{$fieldname}` VARCHAR(255) NOT NULL DEFAULT '{$defaultvalue}'
【insert into table 插入多条数据】
INSERT INTO tablename VALUES(item1, price1, qty1),(item2, price2, qty2),(item3, price3, qty3);
【转数组格式】
方法一:$settings = array('setting'=>$data_setting);
方法二:$settings['setting'] = $data_setting;(推荐)
模型专题
字符串查询(预处理机制)
$models = new ModelsModel;
//判断模型是否存在,采用字段串条件查询,配合预处理机制
if($models::where("id!=:id AND (tablename=:tablename OR name=:name)")
->bind([
'id'=>$id,
'tablename'=>$data['tablename'],
'name'=>$data['name']
])->count()){
return error('模型已经存在!');
exit;
}
【多个条件或判断】whereOr()
//判断新模型是否存在
$models = new ModelsModel;
if($models::where('tablename',$data['tablename'])->whereOr('name',$data['name'])->count()){
return error('模型已经存在!');
exit();
}
【多个条件或判断】where()
//判断新模型是否存在
$models = new ModelsModel;
if($models::where('tablename',$data['tablename'])->where('name',$data['name'])->count()){
return error('模型已经存在!');
exit();
}
前台指定调用条数
offset=0 length=4(从第一条开始,总共调用4条数据
<ul class="qy-mod-ul">
{volist name="today_hot_list" id="thl_vo" offset=0 length=4}
<li class="qy-mod-li">
<div class="qy-mod-img horizon">
<div class="qy-mod-link-wrap">
<a href="/index/play?id={$thl_vo.id}" rel="external nofollow" rel="external nofollow" target="_blank" title="{$thl_vo.title}" class="qy-mod-link">
<img src="{$thl_vo.img}" rseat="712211_focus_juchangimage" alt="{$thl_vo.title}" class="qy-mod-cover">
<div class="icon-tl"></div>
<div class="icon-bl"></div>
</a></div>
<div class="title-wrap"><p class="main">
<a target="_blank" title="{$thl_vo.title}" href="/index/play?id={$thl_vo.id}" rel="external nofollow" rel="external nofollow" rseat="712211_focus_juchangtitle" class="link-txt"> {$thl_vo.title} </a>
</p></div>
</div>
</li>
{/volist}
</ul>
奇偶循环调用
$key:是从0开始的
$i:是从1开始的
思路:取模运算,当是奇数的时候,循环输出奇数和偶数内容
{volist name="channel_list" id="cvo"}
{if condition="$i%2 eq 1"}
<div class="nav-list">
<div class="nav-list-item"><a target="_blank" rseat="712211_channel_yule"
href="/index.php/index/index/cate?label_channel={$cvo.id}" rel="external nofollow" class="nav-list-link">{$cvo.title}</a>
</div>
<div class="nav-list-item"><a target="_blank" rseat="712211_channel_zixun"
href="/index.php/index/index/cate?label_channel=<?php echo $channel_list[$key + 1]['id']?>" rel="external nofollow" class="nav-list-link"><?php echo $channel_list[$key + 1]['title']?></a>
</div>
</div>
{/if}
{/volist}
自动切换
1、前端模板
<div id="piclist" class="qy-focus-index-list">
<ul class="focus-index-list">
{volist name="data" id="ivo"}
<li class="focus-index-item" rseat="fcs_0_p<?php echo $i;?>" style=" opacity: 1;<?php if($i>1){echo 'display: none;';}?>">
<a target="_blank" href="{$ivo.url}" rel="external nofollow"
class="focus-index-itemLink"><img src="{$ivo.img}"></a>
</li>
{/volist}
</ul>
</div>
<div class="qy-focus-side-panel">
<div class="focus-side-inner">
<ul id="txtlist" class="focus-side-list">
{volist name="data" id="vo"}
<li class="focus-side-item<?php if($i==1){echo ' selected';}?>">
<a title="{$vo.title}" rseat="{$i}" class="focus-side-itemLink">{$vo.title}</a>
</li>
{/volist}
</ul>
</div>
</div>
2、JS功能实现
<script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script type="text/javascript">
$('.focus-side-itemLink').on('mouseover',function(){
$(this).parent('li').addClass('selected').siblings('li').removeClass('selected');
var i = $(this).attr('rseat');
$('.focus-index-list li[rseat="fcs_0_p'+i+'"]').show().siblings('li').hide();
});
</script>
加红关键字
<a href="">{$v.username|str_replace=$keyword, '<font style=" rel="external nofollow" color:red">' . $keyword . '</font>', ###}</a>