yii2.0下拉列表的使用

 1 第一种方法:ActiveForm 类的 dropDownList 方法(优点,默认使用yii的样式)
 2
 3 1、在控制器的方法里面 ,我们需要拿到数据,一定是 findAll() 或者是 all() 方法的数据,实例如下:
 4  public function actionIndex()
 5     {
 6         $model = new UserModel();
 7         $data = Customer::find()->all();
 8  //类似这样 :data = [[‘id‘=>1,‘customer_name‘=>‘角色‘],[‘id‘=>2,‘customer_name‘=>‘权限‘]];
 9         return $this->render(‘index‘, [
10             ‘model‘ => $model,
11             ‘data‘ => $data,
12         ]);
13     }
14
15 2、在视图页面,我们使用 yii 的表单生成器。
16 <?phpuse yii\helpers\Html;
17 use yii\widgets\ActiveForm;?>
18 <?php $form = ActiveForm::begin(); ?>
19
20 $form->field($model, ‘username‘)->dropDownList(yii\helpers\ArrayHelper::map($data,‘id‘, ‘customer_name‘),[‘prompt‘=>‘请选择‘,‘style‘=>‘width:100px‘,‘name‘=>‘user‘]);
21
22 2.1、dropDownList           --->     yii2.0  下拉列表的方法
23 2.2、ArrayHelper::map()     --->     构建一个(key => value) 的一维或多维数组
24 2.3.1、 $data               --->     数据源
25 2.3.2、 id                  --->     option 的 value 值
26 2.3.3、 customer_name       --->     option 标签的值
27
28
29
30 第二种方法:Html 类的 activeDropDownList方法(优点,可以自定义任何样式)
31 1、和第一种方法的第一步一样,拿到数据。不多解释了。
32 2、\yii\helpers\Html 类为我们提供了下拉列表的实现方法 activeDropDownList 方法
33 yii\helpers\Html::activeDropDownList($model, ‘username‘, yii\helpers\ArrayHelper::map($data,‘id‘, ‘customer_name‘), [‘style‘ => ‘border:1px solid red;‘]);
34
35 我没写 php 标签,大家自己复制代码,自己加上标签
36 参数和第一种方法的参数含义相同,不做解释。
37
38
39 第三种方法:Html 类的 dropDownList方法(优点,可以自定义任何样式)
40 1、和第一种方法的第一步一样,拿到数据。不过多解释了。
41 2、\yii\helpers\Html 类为我们提供了下拉列表的实现方法 dropDownList方法
42 <?=yii\helpers\Html::dropDownList(‘user‘, null, yii\helpers\ArrayHelper::map($data,‘admin_id‘, ‘admin_user‘), [‘class‘ => ‘sel‘,‘prompt‘=>‘请选择‘]);?>    

如有哪里不对的地方,可以说说。互相交流,互相提升

时间: 2024-10-29 19:06:08

yii2.0下拉列表的使用的相关文章

Yii2.0实用功能技巧解密之——分页功能

Yii中的分页功能主要由yii\web: Linkable接口.yii\widgets: LinkPager类和yii\data: Pagination类三个组成. yii\data: Pagination 主要功能是对分页中的参数进行设置,如当前页.每页大小.总页数,总记录数等. yii\widgets: LinkPager 主要是根据yii\data: Pagination类所提供的参数生成前台页面的分页html代码. 使用:先在action里面生成分页对象,然后在前台的LinkPager中

BUG YII2.0 $ is not defined

BUG描述:$ is not defined 没有加载jquery成功 原因:Yii2.0将JS代码默认加载页面加载后 解决方案: 第一种方案:最简单方法是在 assets\AppAsset.php 中加上,页面前加载 public $jsOptions = array( 'position' => \yii\web\View::POS_HEAD ); 第二种方案:But in production you usually want the scripts to load last, and i

[moka同学笔记]三、Yii2.0课程笔记(魏曦老师教程)

关联字段增加搜索 post表关联adminuser表,通过post.author_id  adminuser.id关联,在YII2.0生成搜索,关联字段搜索时,需要输入关联字段author的id才能搜索,这不符合我们的要求,我们要求输入作者名就可以搜索出来,该作者对应的post.

PHP框架Yii2.0安装(基础版、高级版)

最近农成也是切入了yiiframework 2.0,就是安装yii2.0就花费了不少的时间,为此做了很多的弯路,特此写一篇博文来给后面学习的同学少走一点的弯路.写的不好的地方欢迎各位学习的同学们能够指点出来. yii2.0的安装,官方提供了两种的安装办法,一种是通过composer来安装,另外一种是通过跟yii1.0的办法直接下载安装包来安装.至于对于第一种composer的安装,农成就不做多余的说明了,这里有很好的安装教程.点击进去就可以看到了,为此农成就不在说了,下面就给大家详细讲讲第二种通

Yii2.0中文开发向导——高级应用程序模板

高级应用程序模板这个模板用在大型的团队开发项目中,而且后台从前台独立分离出来以便于部署在多个服务器中.由于YIi2.0的一些新的特性,这个程序模板的功能要更深一点.提供了基本的数据库的支持,注册.密码找回等功能.安装可以通过Composer来安装如果没有安装Composer,先安装 curl -s http://getcomposer.org/installer | php 然后用如下命令来获取 php composer.phar create-project --prefer-dist --s

Yii2.0 实现RESTful风格的简单API

一.创建数据库 首先,在mysql中创建一个名为yii2basic的数据库,并创建一张名为player的表. 二.配置 1.app/config/db.php <?php return [ 'class' => 'yii\db\Connection', 'dsn' => 'mysql:host=localhost;dbname=yii2basic', 'username' => 'root', 'password' => '', 'charset' => 'utf8',

yii2.0数据库查询修改等方法

yii2.0学习有一段时间了,给大家分享一下一些简单的查询等如何操作. 查询:(这里最前面的Test是引用的模型名) Test::find()->all();    此方法返回所有数据: 这些查询出来是对象形式,但是一般转换成数组格式: Test::find()->asArray()->all();     加上asArray()就取得数组形式的数据了,下面的自行添加. Test::findOne($id);   此方法返回 主键 id=1  的一条数据(举个例子): 条件查询:wher

yii2.0 框架 载入 PHPExcel 类

我用的是composer 安装的, 自己引入的话找了好多的方法但是都不能引入 所以找了这个简单一点的. composer require "phpoffice/phpexcel"    用这个命令下载就可以(等一会时间),前提是你已经安装的composer 如果没有,就安装一个,就不多说了. 安装完成后 window 下打开命令窗口 输入compposer 查看是否安装成功,然后打开你的yii2.0(高级版)框架的verdor 这个文件夹 Shift+右键,打开命令窗口,运行上面那个下

Yii2.0高级框架数据库增删改查的一些操作(转)

yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 ----------------------------------------------------------------------------------------------------- User::find()->all();    //返回所有用户数据:User::findOne($id);   //返回 主键 id=1  的一条数