归纳总结thinkphp6常用功能

422 阅读4分钟

第一步更换composer镜像

阿里镜像:composer config -g repo.packagist composer mirrors.aliyun.com/composer/

Laravel China镜像: composer config -g repo.packagist composer packagist.laravel-china.org

中国全量镜像:composer config -g repo.packagist composer packagist.phpcomposer.com9

在码云或者git下载案例发现没有vendor无法运行

composer install --ignore-platform-reqs

或者

composer update --ignore-platform-reqs

Tp6使用

1、下载tp6
composer create-project topthink/think tp

2、设置多应用模式
tp6默认是单应用访问默认进入app/controller里的方法,如果需要做多应用开发(例:http://.com/admin、http://.com/index)需要开启多应用模式

composer requiretopthink/think-multi-app

php think build 应用名称(例:index或者admin)

3、模板渲染

1 tp3: ``$this`` ->display();tp5: ``return $this`` ->fetch();tp6: ``return View::fetch(``'index'``);

tp6默认缺少很多依赖包的,需要下载

composer require topthink/think-view

控制器引入

use think\facade\View;

4、模板跳转重定向
在这里插入图片描述

composer require liliuwei/thinkphp-jump

控制器引入

头部引入:use \liliuwei\think\Jump;

类内引入:use Jump;

如果报错:

查看app/config/jump.php是否有设置:

1'dispatch_success_tmpl' => app()->getRootPath().``'/vendor/qeq66/think-jump/template/jump.html'``,``'dispatch_error_tmpl' => app()->getRootPath().``'/vendor/qeq66/think-jump/template/jump.html'

5、获取表单数据
控制器引入

1use think\facade\Request;``$code = Request::param(``'code'``);

或者

1$code = input(``"code"``);

6、数字验证码
composer require topthink/think-captcha

在应用app目录下找到全局中间件middleware.php文件,把下面注释的代码\think\middleware\SessionInit::class开启

7、上传图片处理图片
composer require topthink/think-image

8、mysql select查询
在这里插入图片描述

从tp5过渡过来的,默认select查询是返回二维数组,tp6返回数据集,虽然官方说和数组操作基本无区别

但是有些时候还是数组好用 例如arr[k][0] = "test"这种间接修改,在默认返回的数据集中,是报错的,但是数组是可以这样操作的
1、

1db::name(``'ceshi'``)->select()->toArray();

2、
修改tp6目录下的/vendor/topthink/think-orm/src/db的BaseQuery.php

在这里插入图片描述

修改示例如图所示,将图中画红框的位置删除,并且在

1$resultSet = ``$this``->connection->select(``$this``);

下面增加一行

1return $resultSet``;

9、分页

1$list = db::name(``'admin_menu'``)->where(``$where``)->paginate([``'list_rows'``=> 10,``'query' => request()->param(),]);

使用paginate方法获取分页数据,查询集合无法新增的下标值

查询条件需要增加 ‘query’ => request()->param(),

解决写法:

php端:

12// An highlighted block$list = db::name('admin_menu')->where($where)->paginate(['list_rows'=> 10,'query' => request()->param(),]);$new_arr = array();foreach($list as $k=>$v){$v[$k]['erji_menu'] = “案例”;$new_arr[] = $v;}``// 获取分页显示$page = $list->render();// 模板变量赋值View::assign('list', $new_arr);View::assign('page', $page);

html端

{$page|raw}

分页引用class修改

tp6\vendor\topthink\think-orm\src\paginator\driver\Bootstrap.php

10、新增数据差异
对比tp5 save方法用于更新 add方法用于添加
tp6 save既是更新也是添加 add方法被删除

1db::name(``'ceshi'``)->where(``array``(``'tz_id'``=>``$post``[``'tz_id'``]))->save(``$users``);db::name(``'ceshi'``)->save(``$users``);

加主键where是更新不加主键是添加,但是会出现问题执行成功只会返回 0,1
不会像tp5 add方法返回添加数据的主键id

| 123456789101112 | /**`` ``* 插入记录`` ``* @access public`` ``* @param array   $data         数据`` ``* @param boolean $getLastInsID 返回自增主键`` ``* @return integer|string`` ``*/``public function insert(``array $data = [], bool ``$getLastInsID = false){``    ``if (!``empty``(``$data``)) {``        ``$this``->options[``'data'`` ] = ``$data``;``    ``}     ``return $this``->connection->insert(``$this`` , ``$getLastInsID``);} | | --------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |

add方法改成了insert方法,虽然注释上面写着返回自增主键,但是我这边测试还是没有拿到自增主键,不清楚是版本问题还是什么这里不深究如果你没遇到就当我没说

| 1234567 | /**`` ``* 插入记录并获取自增ID`` ``* @access public`` ``* @param array $data 数据`` ``* @return integer|string`` ``*/``public function insertGetId(``array $data``){``    ``return $this``->insert(``$data``, true);} | | ------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |

然后拿不到只能继续找发现有一个insertGetId可以拿到。也就是说为了快速开发,平时还是用save解决,遇到要拿自增主键就换成insertGetId

11、tp6 高级查询and和or同时使用
在这里插入图片描述
tp6针对and查询和or查询有快捷方法
在这里插入图片描述
但是这些快捷方法会有很多局限性,当我们对数据进行一系列的复杂查询时这些快捷方法就会出现很多问题例如:

1234567$where1``[] = [``"order_khname"``,``"like"``,``'%'``.``$keywords``.``'%'``];``$where2``[] = [``"order_khqq"``,``"like"``,``'%'``.``$keywords``.``'%'``];``$where3``[] = [``"order_khmobile"``,``"like"``,``'%'``.``$keywords``.``'%'``];``$where``[] = [``"order_type"``,``"="``,``$ddzt``];``$list = db::name(``'ceshi'``)``    ``->where(``$where``)``    ``->whereOr([``$where1``,``$where2``,``$where3``])``    ``->paginate([``        ``'list_rows'``=> 10,``        ``'query' => request()->param(),``    ``]);

这里我们想要的sql格式为:

1SELECT * FROM `dc_ceshi` WHERE  `order_type` = 0 ```and` ( ( order_khname LIKE '%1%'` `` )  OR ( `order_khqq` LIKE '%1%'`` )  OR (order_khmobile LIKE ```'%1%' )) LIMIT 0,10

实际生成的格式为:

1SELECT * FROM `dc_ceshi` WHERE  `order_type` = 0 OR ( `order_khname` LIKE ```'%1%'` )  OR ( order_khqq LIKE '%1%'` `` )  OR ( `order_khmobile` LIKE '%1%' ) LIMIT 0,10`

这里就可以用到闭包查询(注:这只是我学习tp6的时候遇到的问题然后在tp6文档里面找到的解决方式,直接用原生sql也是可以解决,把where条件直接改成一个自定义的字符串也可以解决,用tp5的连接方式也应该可以但是我没试)

12345678910$list = db::name(``'ceshi'``)``    ``->where(``function (``$query`` ) ``use (``$keywords``){``            ``$query``->where(``"order_khname"``,``"like"``,``'%'``.``$keywords``.``'%'``)``                ``->whereOr(``"order_khqq"``,``"like"``,``'%'``.``$keywords``.``'%'``)``                ``->whereOr(``"order_khmobile"``,``"like"``,``'%'``.``$keywords``.``'%'``);``        ``})``    ``->where(``$where``)``    ``->paginate([``    ``'list_rows'``=> 10,``    ``'query' => request()->param(),]);

这时候得到sql格式为:

1SELECT * FROM `dc_ceshi` WHERE  (  `order_khname` LIKE ```'%1%'` OR order_khqq LIKE '%1%'`  `` OR `order_khmobile` LIKE '%1%'``)  ANDorder_type` = 0 LIMIT 0,10``

已经满足了我的需求,但是还是有一个问题就是如果keywords这个变量没有值的时候他查询的语句格式为:

1SELECT * FROM `dc_ceshi` WHERE  (  `order_khname` LIKE ```'%%'` OR order_khqq LIKE '%%'`  `` OR `order_khmobile` LIKE '%%'``)  ANDorder_type` = 0 LIMIT 0,10``

这种情况只需要在加个if判断:

123456789101112$list = db::name(``'ceshi'``)``    ``->where(``function (``$query`` ) ``use (``$keywords``){``        ``if``(``$keywords``){``            ``$query``->where(``"order_khname"``,``"like"``,``'%'``.``$keywords``.``'%'``)``                ``->whereOr(``"order_khqq"``,``"like"``,``'%'``.``$keywords``.``'%'``)``                ``->whereOr(``"order_khmobile"``,``"like"``,``'%'``.``$keywords``.``'%'``);``        ``}``        ``})``    ``->where(``$where``)``    ``->paginate([``    ``'list_rows'``=> 10,``    ``'query' => request()->param(),]);

12、tp6 find查询变动
tp5、tp3我们查询一个表是否存在数据可以直接查询一条

1$datafind = db::name(``'ceshi'``)->find();

tp6 find查询必须增加where条件或者order排序,为什么不知道。有大神知道指点下O(∩_∩)O哈哈~

1$datafind = db::name(``'ceshi'``)->order(``'ID DESC'``)->find();

源码附件已经打包好上传到百度云了,大家自行下载即可~

链接: https://pan.baidu.com/s/14G-bpVthImHD4eosZUNSFA?pwd=yu27
提取码: yu27

百度云链接不稳定,随时可能会失效,大家抓紧保存哈。

如果百度云链接失效了的话,请留言告诉我,我看到后会及时更新~

开源地址

码云地址:
github.crmeb.net/u/defu

Github 地址:
github.crmeb.net/u/defu

开源不易,Star 以表尊重,感兴趣的朋友欢迎 Star,提交 PR,一起维护开源项目,造福更多人!

原文链接:www.php.cn/phpkj/think…