thinkphp6常用功能有哪些

今天小编给大家分享一下thinkphp6常用功能有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

创新互联公司专注于彭山网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供彭山营销型网站建设,彭山网站制作、彭山网页设计、彭山网站官网定制、微信小程序定制开发服务,打造彭山网络公司原创品牌,更为您提供彭山网站排名全网营销落地服务。

第一步更换composer镜像

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

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

中国全量镜像:composer config -g repo.packagist composer https://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、模板渲染

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是否有设置:

'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、获取表单数据
控制器引入

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

或者

$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、

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

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

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

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

下面增加一行

return $resultSet;

9、分页

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

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

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

解决写法:

php端:

// 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方法被删除

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

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

/**
 * 插入记录
 * @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方法,虽然注释上面写着返回自增主键,但是我这边测试还是没有拿到自增主键,不清楚是版本问题还是什么这里不深究如果你没遇到就当我没说

/**
 * 插入记录并获取自增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查询有快捷方法

但是这些快捷方法会有很多局限性,当我们对数据进行一系列的复杂查询时这些快捷方法就会出现很多问题例如:

$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格式为:

SELECT * 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

实际生成的格式为:

SELECT * 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的连接方式也应该可以但是我没试)

$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格式为:

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

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

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

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

$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我们查询一个表是否存在数据可以直接查询一条

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

tp6find查询必须增加where条件或者order排序

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

以上就是“thinkphp6常用功能有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注创新互联行业资讯频道。


标题名称:thinkphp6常用功能有哪些
本文网址:http://myzitong.com/article/ipcegc.html