广告:宝塔Linux面板高效运维的服务器管理软件 点击【 https://www.bt.cn/p/uNLv1L 】立即购买
本篇文章给大家带来了关于thinkphp的相关知识,其中主要整理了一些常用的功能,包括获取表单数据、设置多应用模式、模板渲染等等相关内容,下面一起来看一下,希望对大家有帮助。
推荐学习:《PHP视频教程》
第一步更换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
'dispatch_success_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html','dispatch_error_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html'0登录后复制
add方法改成了insert方法,虽然注释上面写着返回自增主键,但是我这边测试还是没有拿到自增主键,不清楚是版本问题还是什么这里不深究如果你没遇到就当我没说
'dispatch_success_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html','dispatch_error_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html'1登录后复制
然后拿不到只能继续找发现有一个insertGetId可以拿到。也就是说为了快速开发,平时还是用save解决,遇到要拿自增主键就换成insertGetId
11、tp6 高级查询and和or同时使用 tp6针对and查询和or查询有快捷方法 但是这些快捷方法会有很多局限性,当我们对数据进行一系列的复杂查询时这些快捷方法就会出现很多问题例如:
'dispatch_success_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html','dispatch_error_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html'2登录后复制
这里我们想要的sql格式为:
'dispatch_success_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html','dispatch_error_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html'3登录后复制
实际生成的格式为:
'dispatch_success_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html','dispatch_error_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html'4登录后复制
这里就可以用到闭包查询(注:这只是我学习tp6的时候遇到的问题然后在tp6文档里面找到的解决方式,直接用原生sql也是可以解决,把where条件直接改成一个自定义的字符串也可以解决,用tp5的连接方式也应该可以但是我没试)
'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登录后复制
这时候得到sql格式为:
'dispatch_success_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html','dispatch_error_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html'6登录后复制
已经满足了我的需求,但是还是有一个问题就是如果keywords这个变量没有值的时候他查询的语句格式为:
'dispatch_success_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html','dispatch_error_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html'7登录后复制
这种情况只需要在加个if判断:
'dispatch_success_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html','dispatch_error_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html'8登录后复制
12、tp6 find查询变动tp5、tp3我们查询一个表是否存在数据可以直接查询一条
'dispatch_success_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html','dispatch_error_tmpl' => app()->getRootPath().'/vendor/qeq66/think-jump/template/jump.html'9登录后复制
tp6 find查询必须增加where条件或者order排序,为什么不知道。有大神知道指点下O(∩_∩)O哈哈~
use think\facade\Request;$code = Request::param('code');0登录后复制
推荐学习:《PHP视频教程》
以上就是归纳总结thinkphp6常用功能的详细内容,更多请关注9543建站博客其它相关文章!
发表评论