Php Yii在数据库的dropdownlist中显示treeview
我在数据库中保存了类别和子类别。我想在CHtml下拉列表中显示它们,如下所示:Php Yii在数据库的dropdownlist中显示treeview,php,database,yii,treeview,html-select,Php,Database,Yii,Treeview,Html Select,我在数据库中保存了类别和子类别。我想在CHtml下拉列表中显示它们,如下所示: Patrent_cat sub_cat1 sub_cat2 Parent_cat2 ... 我的分类表是这样的 id name parent_id 如果元组本身是父元组,则parent_id为0 我已经在我的分类模型中尝试过: public function relations() { return array( 'getparent' => arra
Patrent_cat
sub_cat1
sub_cat2
Parent_cat2
...
我的分类表是这样的
id name parent_id
如果元组本身是父元组,则parent_id为0
我已经在我的分类模型中尝试过:
public function relations()
{
return array(
'getparent' => array(self::BELONGS_TO, 'Category', 'parent_id'),
'childs' => array(self::HAS_MANY, 'Category', 'parent_id', 'order' => 'id ASC'),
);
}
public function getCategoryTree()
{
$subitems = array();
if($this->childs) foreach($this->childs as $child)
{
$subitems[] = $child->getListed();
}
$returnarray = array($this->id => $this->title);
if($subitems != array())
$returnarray = array_merge($returnarray, array('items' => $subitems));
return $returnarray;
}
在我看来:
<?php
echo CHtml::dropDownList('category', 'id',
Category::model()->CategoryTree,
array('empty' => '(Select a category'));
?>
但它给了我一个空下拉列表。如何使用选项组在dropdownlist中显示此树视图?(选项组是父类别,选项是子类别。试试这个
echo $form->dropDownList($model,'id',CHtml::listData(SubCat::model()->findAll(),'id', 'name','relation_name.name'),array('prompt'=>'Choose'));
这将在下拉列表中显示父类别和子类别您创建了空模型并尝试获取其子类别Category::model()->CategoryTree,这样您就得到了空结果 尝试方法获取模型中的子类别列表:
public function getChildList() {
$return = array();
if ($this->childs !== null) {
foreach ($this->childs as $child) {
$return[$child->id] = "--".$child->title;
}
}
return $return;
}
在控制器操作上:
...
$categotyList = array();
$parentCategories = Category::model()->findAllByAttributes(array('parent_id'=>'0'));
foreach ($parentCategories as $category) {
array_merge($categoryList,
array('$category->id' => '$category->name'),
$category->getChildList()
);
}
...
和视图:
echo CHtml::dropDownList('category', 'id',
$categoryList,
array('empty' => '(Select a category'));
检查代码是否有错误,并根据需要进行修改。它可以工作,但它只显示所有类别,它不会将父类别和子类别分开这应该可以工作,只是
子类别将是类别
本身,而关系名称
将是getparent
@bool.dev谢谢,它正在与rela一起工作只需再问一个问题,现在在下拉列表中,我首先看到所有类别和子类别的列表,然后重复我想要的结果(parentcats作为组,sub_cats作为选项,因此,我认为我应该删除一些内容,对吗?您确定所有子类别也显示在顶部吗?根据我的说法,只有父类别(parent_id=0)将显示在顶部,然后是分组的子类别。我将条件添加到findAll以仅获取子类别,现在它可以工作了,谢谢大家getCategoryTree
函数如果不初始化$this
,当您使用静态模型$调用它时,
将为空
public function getDropdownCategories()
{
$array = self::find()->select(['id', 'parent_id', 'name'])->asArray()->all();
$array = self::buildTree($array);
$array = ArrayHelper::map($array, 'id', 'name');
return $array;
}
private function buildTree($array, $parentId = null, $preWord = '')
{
if(!empty($preWord))
$preWord.='-';
$tmpArray = [];
foreach ($array as $element) {
if ($element['parent_id'] == $parentId) {
$tmpArray[] = ['id' => $element['id'], 'name' => $preWord.$element['name']];
$tmp = self::buildTree($array, $element['id'], '-');
if(!empty($tmp) && is_array($tmp)) {
foreach ($tmp as $item) {
$tmpArray[] = ['id' => $item['id'], 'name' => $item['name']];
}
}
}
}
return $tmpArray;
}