Thinkphp5.0第四篇

删除数据

当前模型删除

$user=UserModel::get(1);
   if($user->delete()){return '删除成功';}
   else{return '删除失败';}

根据主键删除单条数据

if(UserModel::destroy(2))return '删除成功';

else return '删除失败';

根据主键删除多条数据

if(UserModel::destroy([3,4])){return '删除多条数据成功';}else{return '删除多条数据失败';}

条件删除

if(UserModel::destroy(['name'=>'陈国松']))return '删除成功';
else return '删除失败';

经过数据库类删除

$result=UserModel::where('id','>',6)->delete();
if($result){
    return '删除成功';
}
else
return '删除失败';
}

视图

视图实例化

视图功能由 \think\View 类配合视图驱动(模板引擎)类一块儿完成,目前的内置模板引擎包含PHP原生模板
和Think模板引擎。
由于新版的控制器能够无需继承任何的基础类,所以在控制器中如何使用视图取决于你怎么定义控制器。php

继承 \think\Controller

若是你的控制器继承了 \think\Controller 类的话,则无需本身实例化视图类,能够直接调用控制器基础
类封装的相关视图类的方法。html

下面的方法能够直接被调用:thinkphp

方法 说明
fetch 渲染模板输出
display 渲染内容输出
assign 模板变量赋值
engine 初始化模板

assign方法

赋值给模板变量数据库

$name='个人滑板鞋';
$email='huabanxie@qq.com';
$this->assign('name',$name);
$this->assign('email',$email);

批量赋值缓存

$this->assign(
['name'=>$name,'email'=>$email]
);

fetch 渲染模板输出cookie

该方法默认渲染的是view/index/index.htmlsession

return $this->fetch();
return $this ->fetch('user/user');
//view下的user下的user.html
return $this->fetch('index',['name'=>'thinkphp','email'=>'thinkphp@qq.com']);//给index.html传赋给的值

助手函数view也能够框架

return view('index',['name'=>'陈国松','email'=>'chenguosong@qq.com']);

模板

ThinkPHP内置了一个基于XML的性能卓越的模板引擎,这是一个专门为ThinkPHP服务的内置模板引擎,使用了XML标签库技术的编译型模板引擎,支持两种类型的模板标签,使用了动态编译和缓存技术,并且支持自定义标签库。函数

模板定位

每一个模块的模板文件是独立的,为了对模板文件更加有效的管理,ThinkPHP对模板文件进行目录划分,性能

默认的模板文件定义规则是:

视图目录/控制器名(小写)/操做名(小写)+模板后缀默认的视图目录是模块的view目录,框架的默认视图文件后缀是 .html

模板标签

普通标签

​ 普通标签用于变量输出和模板注释,普通模板标签默认以 { 和 } 做为开始和结束标识,而且在开始标记紧
跟标签的定义,若是之间有空格或者换行则被视为非模板标签直接输出。 例如: {$name} 、
{$vo.name} 、 {$vo['name']|strtoupper} 都属于正确的标签,而 { $name} 、
{ $vo.name} 则不属于。

能够经过修改config.php里面的模板设置开始和结束标识

系统变量

系统变量输出

{$Think.server.script_name} // 输出$_SERVER['SCRIPT_NAME']变量{$Think.session.user_id} // 输出$_SESSION['user_id']变量{$Think.get.pageNumber} // 输出$_GET['pageNumber']变量{$Think.cookie.name} // 输出$_COOKIE['name']

支持输出 $_SERVER 、 $_ENV 、 $_POST 、 $_GET 、 $_REQUEST 、 $_SESSION 和$_COOKIE 变量

常量输出

在控制器文件里定义的常量

{$Think.APP_PATH}

输出配置参数

{$Think.config.default_module}{$Think.config.default_controller}

使用函数

{$data.name|md}

编译后是

<?php echo (md5($data['name']));

若是函数有多个参数须要调用,则使用:

{$create_time|date="y-m-d",###}

表示date函数传入两个参数,每一个参数用逗号分割,这里第一个参数是 y-m-d ,第二个参数是前面要输出的
create_time 变量,由于该变量是第二个参数,所以须要用###标识变量位置,编译后的结果是:

<?php echo (date("y-m-d",$create_time)); ?>

若是前面输出的变量在后面定义的函数的第一个参数,则能够直接使用:

{$data.name|substr=0,3}

表示输出

<?php echo (substr($data['name'],0,3)); ?>

虽然也能够使用:

{$data.name|substr=###,0,3}

但彻底没用这个必要。
还能够支持多个函数过滤,多个函数之间用“|”分割便可,例如:

{$name|md5|strtoupper|substr=0,3}

编译后的结果是:

<?php echo (substr(strtoupper(md5($name)),0,3)); ?>

使用函数函数会按照从左到右的顺序依次调用。
若是你以为这样写起来比较麻烦,也能够直接这样写:

{:substr(strtoupper(md5($name)),0,3)}

变量输出使用的函数能够支持内置的PHP函数或者用户自定义函数,甚至是静态方法。

相关文章
相关标签/搜索