5

Select フォーム要素を入力しています。値に HTML エンティティを使用しようとすると、特殊文字が表示されずに変換されます。

このコード:

$form->field_name->addMultiOption('value', ' • label');

レンダリング:

<option value="one">&amp;nbsp;&amp;bull; label</option>

しかし、私はそれが欲しい:

<option value="one">&nbsp;&bull; label</option>

ここで HTML エンティティを使用するにはどうすればよいですか?


ヒント?

コードを掘り下げたところescape()、Zend View Abstract の関数をラベル値で使用していることがわかりました。特定のフォーム要素に対してこの関数をオーバーライド/オーバーロードする方法を誰かが知っているでしょうか? デフォルトでその動作をオーバーライドしたくありません。

Zend_View_Helper_FormSelectクラスからの関数

protected function _build($value, $label, $selected, $disable)
{
    if (is_bool($disable)) {
        $disable = array();
    }

    $opt = '<option'
         . ' value="' . $this->view->escape($value) . '"'
         . ' label="' . $this->view->escape($label) . '"';

    // selected?
    if (in_array((string) $value, $selected)) {
        $opt .= ' selected="selected"';
    }

    // disabled?
    if (in_array($value, $disable)) {
        $opt .= ' disabled="disabled"';
    }

    $opt .= '>' . $this->view->escape($label) . "</option>";

    return $opt;
}

これはZend_View_Abstractクラスの関数です:

private $_escape = 'htmlspecialchars';

/* SNIP */

public function escape($var)
{
    if (in_array($this->_escape, array('htmlspecialchars', 'htmlentities'))) {
        return call_user_func($this->_escape, $var, ENT_COMPAT, $this->_encoding);
    }

    return call_user_func($this->_escape, $var);
}
4

2 に答える 2

10

これは私が作っていたほど複雑ではないことがわかりました。

私はこれを変更しました:

$form->field_name->addMultiOption('value', '&nbsp;&bull; label');

これに:

$form->field_name->addMultiOption('value',
    html_entity_decode('&nbsp;&bull;', ENT_COMPAT, 'UTF-8') . ' label');
于 2010-02-23T19:30:09.673 に答える
1

特定のフィールドにデータを入力するときに、Zend フィルターのオフ/クリアを試みることができます。

$form->getElement('yourElementName')->clearFilters();
// pupulate the element 

Zend フィルターをクリアすると、独自の事前入力を適用できます。

于 2010-02-21T01:19:06.803 に答える