【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="https://www.atool.online/article/{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="https://www.atool.online/article/{: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="https://www.atool.online/index/play?id={$thl_vo.id}" rel="external nofollow" rel="external nofollow" target="_blank" title="{$thl_vo.title}" class="qy-mod-link"> <img src="https://www.atool.online/article/{$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="https://www.atool.online/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="https://www.atool.online/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="https://www.atool.online/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="https://www.atool.online/article/{$ivo.url}" rel="external nofollow" class="focus-index-itemLink"><img src="https://www.atool.online/article/{$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>
到此这篇关于thinkphp5实用入门进阶知识点和各种常用功能代码汇总的文章就介绍到这了,更多相关thinkphp5常用功能代码内容请搜索阿兔在线工具以前的文章或继续浏览下面的相关文章希望大家以后多多支持阿兔在线工具!