在Yii 2中,页面上用表格显示数据时,通常是用数据提供器(Data Provider)来给表格做为数据源,这个思路就是无论你数据来源是什么,可是最终提供给页面表格显示的时候,其格式和接口都是一致的,这样就有效的实现了先后台的解耦。php
在实际开发中,最经常使用的是ActiveDataProvider和SqlDataProvider,一个是使用ORM的方式从数据库获取数据,另外一种是直接使用SQL语句获取数据,各有各的适用场合,使用起来也很是方便。前端
在Yii 2中,还提供了ArrayDataProvider,顾名思义,就是用数组做为数据源,这个用的比较少,所以一开始的时候仍是有点生疏。数据库
简单跟踪一下代码就能够知道,前端表格在显示数据的时候,其核心是要求数据以关联数组的数组形式提供出来,因此使用ArrayDataProvider的时候,也是以这种形式提供数据就行了,基本的数组格式相似以下:数组
$data = [ [ 'name' => 'zhangfei', 'age' => 20, ], [ 'name' => 'guanyu', 'age' => 20, ], ]
其实这个结构,跟使用Model查询获得的数据asArray()出来的结果是同样的。ide
首先,要按照显示的数据内容,定义一个Model,其实不定义Model也能够,只要按照显示的要求组织好关联数组就能够了,可是定义Model,能够方便将来实现查询、过滤。
Model的定义大体以下:工具
class ArrStudentModel extends Model { public $name; public $age; /** * @inheritdoc */ public function rules() { return [ [['name'], 'string'], [['age'], 'integer'] ]; } /** * @inheritdoc */ public function attributeLabels() { return [ 'name' => '姓名', 'age' => '年龄', ]; } }
看这个Model的结构是否是很眼熟,没错,跟使用Yii 2的工具自动生成的表Model是同样同样的,固然,懒一点,不继承实现rules()和attributeLabels()也是没问题的。不过,rules()能够为之后自动查询提供默认的规则,而attributeLabels()能够为表格提供列标题的文字,因此搞一个Model比较合适。code
查询的作法也很简单,跟ActiveRecord一样处理,在Model中提供查询的接口便可。继承