• 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 '删除失败';
    }
    

    视图

    视图实例化

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

    继承 hinkController

    如果你的控制器继承了 hinkController 类的话,则无需自己实例化视图类,可以直接调用控制器基础
    类封装的相关视图类的方法。

    下面的方法可以直接被调用:

    方法 说明
    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 渲染模板输出

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

    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函数或者用户自定义函数,甚至是静态方法。

  • 相关阅读:
    只打开一次浏览器,生成html测试报告<小紧张中......>
    hadoop学习第四天-Writable和WritableComparable序列化接口的使用&&MapReduce中传递javaBean的简单例子
    hadoop学习第三天-MapReduce介绍&&WordCount示例&&倒排索引示例
    hadoop学习第二天-了解HDFS的基本概念&&分布式集群的搭建&&HDFS基本命令的使用
    hadoop学习第一天-hadoop初步环境搭建&伪分布式计算配置(详细)
    大三了,写写博客
    方向问题
    第一天注册博客
    jquery跨域请求事例
    ECharts学习记录
  • 原文地址:https://www.cnblogs.com/chenguosong/p/11494129.html
Copyright © 2020-2023  润新知