在zend2中动态设置SELECT属性

时间:2013-04-19 06:26:16

标签: zend-framework2

我实际上在做的是从数据库中获取公司列表并将其传递给表单SELECT元素。 所以我创建了一个模型文件,它返回一个数组

//=== return an array of $ID => $name of companies to use in dropdown in reports form
public function getTotalResult($table, $type, $id) {
        $this->table = $table;
        $select = new Select();
        $spec = new  Where();
        $spec->equalTo('status', 1);
        if ($type == 'name') {
            $spec->equalTo('id', $id);
        }
        $select->from($this->table);

        $select->where($spec);
        $resultSet = $this->selectWith($select);
        //$resultSet->buffer();
        return $resultSet;

}
public function resultList($table){
    $results = $this->getTotalResult($table, '', '');
    foreach ($results as $result) {
        $this->id[] = $result->id;
        $this->name[] = $result->name;
    }
    $result = array_combine($this->id, $this->name);
    return $result;

}

然后我在我的Controller中测试了这个,它完全返回了我想要的内容:

use Zend\Mvc\Controller\AbstractActionController;
use Zend\View\Model\ViewModel;
use SpangelLogin\Model\Register;          // <-- Add this import
use SpangelLogin\Model\companyList;          // <-- Add this import
class RegisterController extends AbstractActionController
{
protected $registerTable;
protected $companyList;

 public function getcompanyList()
{
    if (!$this->companyList) {
        $sm = $this->getServiceLocator();
        $this->companyList = $sm->get('SpangelLogin\Model\companyList');
    }
    return $this->companyList;
}

public function indexAction()
{
    //== get list of companies
    $company_table = 'rs_company';
    $sector_table = 'rs_sector';
    $companiesList = $this->getcompanyList()->getName($company_table, 2);

 }
}

所以现在我希望在我的表单的Select Element中传递这个companiesList数组。我怎样才能做到这一点。这是我使用select的表单。

use Zend\Form\Form;

使用Zend \ Form \ Element;

类Sec​​torReportForm扩展Form {

public function __construct($name = null)
{
    // we want to ignore the name passed
    parent::__construct('sectorreport');
    $companiesArray =  $this->companiesList();
    $sectorsArray =  $this->sectorsList();

    $this->setAttribute('method', 'post');
    $this->setAttribute('enctype','multipart/form-data');

    $this->add(array(     
        'type' => 'Zend\Form\Element\Select',       
        'name' => 'company',
        'attributes' =>  array(
            'id' => 'company',  
            'multiple' => true,               
            'options' => $companiesArray,
        ),
        'options' => array(
            'label' => 'Company',
        ),
    ));  


    $this->add(array(
        'name' => 'submit',
        'attributes' => array(
            'type'  => 'submit',
            'value' => 'Upload',
            'id' => 'submitbutton',
            'class' => 'button violet right'
        ),
    ));
}


}

1 个答案:

答案 0 :(得分:1)

从Design-Perspective,最好的方法是通过Dependency-Injection来处理这个问题。这个偷偷摸摸的小流行语让人们如此困惑,但实际上只不过是在对象之间转发数据:P

表格的一般依赖 - 注入可以看到以下答案,以及我的博客文章

如果您不想采用这种方法,您也可以在控制器级别处理此问题。

$form   = new My\Form();
$select = $form->get('selectCountries');

$model    = new My\Countries();
$listData = $model->getCountriesAsArray();

$select->setValueOptions($listData);

我仍然建议你采用不同的方法;)保持控制器更干净,这总是一件好事。分离关注!