ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

php – 使用yii中的关系创建下拉列表

2019-06-24 23:18:09  阅读:169  来源: 互联网

标签:php html-select entity-relationship yii


我是Yii框架中的新手,现在我尝试从相关表创建下拉列表.
我有表“新闻”[…很多字段,类别]和“NewsCategories”[id,category_name].
在用于在新闻中创建新记录的表单中,当用户可以选择category_name时,我想在类别字段中创建下拉列表,但类别的id必须在新记录中记录.

请帮帮我.对不起我的英语不好.我希望我解释它是可以理解的.

这就是我创建关系的方式

型号News.php

public function relations()
{

    // NOTE: you may need to adjust the relation name and the related
    // class name for the relations automatically generated below.
    return array(
    'category'=>array(self::BELONGS_TO, 'NewsCategories', 'category'),
    );
}

Model NewsCategories.php

    public function relations()
{
    // NOTE: you may need to adjust the relation name and the related
    // class name for the relations automatically generated below.
    return array(
    'news'=>array(self::HAS_MANY, 'News', 'id'),
    );
}

以及我如何尝试创建下拉列表:

<?php echo $form->dropDownList($model,'category',CHtml::listdata(News::model()->with('category')->findAll(),'id','category_name'),array('empty'=>'(Select a category')));?>

解决方法:

指定关系时,您不需要指定主键(id),因为yii可以从模型中扣除主键.您只需指定另一端,因此您的NewsCategory关系应如​​下所示:

'news'=>array(self::HAS_MANY, 'News', 'category'),

要获取适合下拉列表的数据,请使用

CHtml::listData(NewsCategories::model()->findAll(), 'id', 'category_name');

标签:php,html-select,entity-relationship,yii
来源: https://codeday.me/bug/20190624/1282551.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有