2

我想我不了解参考领域。

我有一个简单的表格

<?php

class page_prueba extends Page {
  function init(){
    parent::init();
    $p=$this;
    $f=$p->add('Form');
    $f->setSource('ticket');
    $f->addField('line','texto')->validateNotNull();
    $f->addField('text','detalle')->validateNotNull();
    $c=$p->add('Model_Usuario');
    $f->addField('reference','usuario')->setValueList($c)->validateNotNull();
  }
}

我有一个用户模型

<?php
  class Model_Usuario extends Model_Table {
    public $entity_code='usuario';
    public $table_alias='u';
    function defineFields(){
      parent::defineFields();           
      $this->addField('nombre');
      $this->addField('password');
      $this->addField('email');
      $this->addField('telefono');
      $this->addField('descripcion');
      $this->addField('interno');
      $this->addField('esadmin');
    }
  }
?>

当我运行示例页面时,我在下拉列表(选项值)上显示了 id 值(主键),但我想在该下拉列表中看到的是名称(名词)字段。

也许我错过了一些东西。

任何帮助将不胜感激。

谢谢亚历杭德罗

4

1 回答 1

1

默认情况下,模型显示“名称”字段。有几种方法可以自定义

  1. 按计算定义名称字段
  2. 重新定义 Model_Usuario::toStringSQL()
  3. 从 4.1 开始,您还可以通过属性定义字段名称。

你可能应该去 2,这里是例子:

public function toStringSQL($source_field, $dest_fieldname, $expr = 'name') {
    // return parent::tostringSQL($source_field,$dest_fieldname, 'date')

    return 'concat(name," ",surname) as ' . $dest_fieldname;
}
于 2011-08-20T12:42:40.423 回答