thinkphp5 return 返回空_thinkphp3和thinkphp5的区别

23e5c40eaaaf6e31721f7f5e14f37352.png

thinkphp3和thinkphp5的区别?下面给大家介绍一下两者的不同之处:

一、thinkphp3.2和thinkphp5之间的使用差异

1、过去的单字母函数已完全被替换掉,如下:

S=>cache,C=>config,M/D=>model,U=>url,I=>input,E=>exception,L=>lang,A=>controller,R=>action

2、模版渲染:

$this->display() => return view()/return $this->fetch();

3、在model中调用自身model:

$this => Db::table($this->table)

4、在新建控制器与模型时的命名:

①控制器去掉后缀controller:UserController => User

②模型去掉后缀model:UserModel => User

5、url访问:

如果控制器名使用驼峰法,访问时需要将各字母之间用下划线链接后进行访问。

eg:控制器名为AddUser,访问是用add_user来进行访问

6、在TP5中支持配置二级参数(即二维数组),配置文件中,二级配置参数读取:

①Config::get('user.type');

②config('user.type');

7、模板中支持三元运算符的运算:

{$info.status ? $info.msg : $info.error}还支持这种写法:{$varname.aa ?? 'xxx'}或{$varname.aa ?: 'xxx'}

相关推荐:《php视频教程》

8、TP5内置标签:

系统内置的标签中,volist、switch、if、elseif、else、foreach、compare(包括所有的比较标签)、(not)present、(not)empty、(not)defined等

9、TP5数据验证:

$validate = new Validate(['name' => 'require|max:25','email' => 'email']);

$data = ['name' => 'thinkphp','email' => 'thinkphp@qq.com'];

if(!validate->check($data)){

debug::dump($validate->getError());

}

注:使用助手函数实例化验证器——$validate = validate('User');

10、TP5实现了内置分页,使用如下:

查询状态为1的用户数据,且每页显示10条数据

$list = model('User')->where('status',1)->paginate(10);

$page = $this->render();

$this->assign('_list',$list);

$this->assign('_page',$page);

return $this->fetch();

模板文件中分页输出代码如下:

{$_page}

第二、thinkphp3.2和thinkphp5数据库操作进行对比

增加数据

thinkhp3.2

//添加单条数据$User = M('User');

$data['name'] = 'ThinkPHP';

$data['email'] = 'ThinkPHP@gmail.com';

$User->create($data);

$User->add($data);//添加多条数据$dataList[] = array('name'=>'thinkphp','email'=>'thinkphp@gamil.com');

$dataList[] = array('name'=>'onethink','email'=>'onethink@gamil.com')

$User->addAll($dataList);

thinkphp5

//添加单条数据$data = ['foo' => 'bar', 'bar' => 'foo'];

Db::table('think_user')->insert($data);//添加多条数据$data = [

['foo' => 'bar', 'bar' => 'foo'],

['foo' => 'bar1', 'bar' => 'foo1'],

['foo' => 'bar2', 'bar' => 'foo2']

];

Db::name('user')->insertAll($data);

修改数据

thinkhp3.2

$User = M("User"); // 实例化User对象// 要修改的数据对象属性赋值

$data['name'] = 'ThinkPHP';$data['email'] = 'ThinkPHP@gmail.com';

$User->where('id=5')->save($data); // 根据条件更新记录

where('id=5')->setField('name','ThinkPHP');

$data = array('name'=>'ThinkPHP','email'=>'ThinkPHP@gmail.com');// 更改用户的name值

$User-> where('id=5')->setField($data);更改用户的name和email的值

$User->where('id=5')->setDec('score',5); // 用户的积分减5

$User->where('id=5')->setInc('score',3); // 用户的积分加3

thinkhp5

Db::table('think_user')->update(['name' => 'thinkphp','id'=>1]);//更新数据表中的数据

Db::table('think_user') ->where('id',1) ->setField('name', 'thinkphp');//更新某个字段的值

Db::table('think_user')->where('id', 1)->setInc('score',5);// score 字段加 5

Db::table('think_user')->where('id', 1)->setDec('score', 5);// score 字段减 5

Db::table('think_user')->where('id', 1)->setInc('score', 1, 10);//支持延时更新

删除数据

thinkhp3.2

$User->delete('1,2,5'); // 删除主键为1,2和5的用户数据

$User->where('status=0')->delete(); // 删除所有状态为0的用户数据

thinkphp5

// 根据主键删除Db::table('think_user')->delete(1);

Db::table('think_user')->delete([1,2,3]);// 条件删除

Db::table('think_user')->where('id',1)->delete();

Db::table('think_user')->where('id','delete();

第三、thinkphp5与thinkphp3.X对比

首先声明本章节并非是指导升级旧的项目到5.0,而是为了使用3.X版本的开发者更快的熟悉并上手这个全新的版本。同时也强烈建议开发者抛弃之前旧的思维模式,因为5.0是一个全新的颠覆重构版本。

需要摒弃的3.X旧思想

URL的变动

首先对3.X的不严谨给开发者们带来的不正确的引导表示歉意,在5.0版本正式废除类似/id/1方式 可以通过‘get’获取到‘id’的方法,严格来讲这样的url是不属于$_GET的,现在可以通过‘param’获取。

模型的变动

新版的模型查询返回默认‘对象’,系统默认增加了'toArray'方法,许多开发者在'all'或'select'尝试使用'toArray'来 转换为数组,在此希望开发者能理解‘对象’的概念,尝试使用‘对象’进行数据的使用,或者使用'db'方法进行数据库的操作,也提醒一下部分‘滥 用’'toArray'的开发者,'all'或'select'结果是对象的数组集合,是无法使用'toArray'进行转换的。

新版变化

命名规范

目录和文件名采用‘小写+下划线’,并且以小写字母开头;类库、函数文件统一以.php为后缀;类的文件名均以命名空间定义,并且命名空间的路径和类库文件所在路径一致(包括大小写);类名和类文件名保持一致,并统一采用驼峰法命名(首字母大写)

函数

系统已经不依赖任何函数,只是对常用的操作封装提供了助手函数;单字母函数废弃,默认系统加载助手函数。

路由

5.0的URL访问不再支持普通URL模式,路由也不支持正则路由定义,而是全部改为规则路由配合变量规则(正则定义)的方式,具体这里不再赘述。

控制器

控制器的命名空间有所调整,并且可以无需继承任何的控制器类。

应用类库的命名空间统一为app(可修改)而不是模块名;控制器的类名默认不带Controller后缀,可以配置开启controller_suffix参数启用控制器类后缀;控制器操作方法采用return方式返回数据,而非直接输出;废除原来的操作前后置方法;

版本对比

3.2版本控制器写法

namespace HomeController;

use ThinkController;

class IndexController extends Controller

{ public function hello()

{ echo 'hello,thinkphp!';

}

}

5.0版本控制器写法

namespace appindexcontroller;

class Index

{ public function index()

{ return 'hello,thinkphp!';

}

}

3.2版本控制器命名

IndexController.class.php

5.0版本控制器命名

Index.php

在控制器中正确的输出模板

5.0在控制器中输出模板,使用方法如下:

如果你继承thinkController的话,可以使用:

return $this->fetch('index/hello');

如果你的控制器没有继承 thinkController的话,使用:

return view('index/hello');

模型

如果非要对比与旧版本的改进,模型被分为数据库、模型、验证器三部分,分别对应M方法、模型、自动验证,同时均有所加强,下面做简单介绍。

数据库

5.0的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过Db类调用,原来的M函数调用可以改用db函数,例如:

3.2版本

M('User')->where(['name'=>'thinkphp'])->find();

5.0版本

db('User')->where('name','thinkphp')->find();

模型

新版的模型查询增加了静态方法,例如:

User::get(1);

User::all();

User::where('id','>',10)->find();

自动验证

对比旧的版本,可以理解为之前的自动验证且不同于之前的验证;

ThinkPHP5.0验证使用独立的hinkValidate类或者验证器进行验证,不仅适用于模型,在控制器也可直接调用。

配置文件

新版对配置很多的配置参数或者配置层次都和之前不同了,建议大家要么看看代码,要么仔细通读下官方的开发手册,不要因为配置的问题浪费自己一整天的时间。

异常

5.0对错误零容忍,默认情况下会对任何级别的错误抛出异常,并且重新设计了异常页面,展示了详尽的错误信息,便于调试。

系统常量的废弃

5.0版本相对于之前版本对系统变化进行了大量的废弃,用户如果有相关需求可以自行定义

下面是废除常量

REQUEST_METHOD IS_GET IS_POST IS_PUT IS_DELETE IS_AJAX __EXT__ COMMON_MODULE MODULE_NAME CONTROLLER_NAME

ACTION_NAME APP_NAMESPACE APP_DEBUG MODULE_PATH等

部分常量可以在Request里面进行获取

助手函数

5.0助手函数和3.2版本的单字母函数对比如下:

0765512d4b59c93a2e2ab094cf32c445.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值