我有:
$this->addElement('select', 'type', array(
'label' => 'Banner type',
'required' => true,
'multiOptions' => array(
'' => 'Please select',
'1' => 'Image',
'3' => 'Flash',
'4' => 'Html'
),
'value' => '',
));
但是当呈现选定的dropdown
时,它具有我不想要的id = "type"
属性。我正在 JavaScript 中克隆它,在所有事件之后它无法正常工作。
你最好修改你的javascript(在克隆元素时更改id)。
如果要使用 ZF 更改表单元素的结构,则必须创建自己的 select 元素扩展Zend_Form_Element_Select,然后创建自己的 formSelect 视图帮助程序扩展Zend_View_Helper_FormSelect并覆盖 formSelect()
方法。然后看看我在下面的评论:
$xhtml = '<select'
. ' name="' . $this->view->escape($name) . '"'
. ' id="' . $this->view->escape($id) . '"' // remove this line
. $multiple
. $disabled
. $this->_htmlAttribs($attribs)
. ">'n ";
克隆元素后,您可以重置/更改元素的 ID
(在你对它做任何事情之前,即注入回 DOM 中)
简单地装箱一个变量来保存克隆并更改其id
属性。 例如:
$(function (){
var div = $('#myId');
console.log(div[0].id); //shows the element id
var newDiv = div.clone(); //clone the element
console.log(newDiv[0].id); //shows original element id
newDiv[0].id = "myNewId"; //change the id
console.log(newDiv[0].id); //shows 'myNewId'
});