PHP 開発フレームワーク Yii Framework チュートリアル (10) UI コンポーネント カスタム コンポーネント

黄舟
リリース: 2023-03-05 07:30:01
オリジナル
1168 人が閲覧しました

Yii の組み込み UI コンポーネントを紹介する前に、まずコンポーネントをカスタマイズする方法を紹介します。これは、CWidget の init() メソッドと run() メソッドをオーバーロードすることによる、CWidget の使用法を理解するのにも役立ちます。

class MyWidget extends CWidget{public function init(){// 此方法会被 CController::beginWidget() 调用}
public function run(){// 此方法会被 CController::endWidget() 调用}}
ログイン後にコピー

この例では、CInputWidget を拡張することによって値範囲入力 UI コンポーネント RangeInputField を定義します。これにより、ユーザーは 2 つの数値を入力して値範囲を定義できるようになります。 CInputWidget は CModel の使用または変数の直接使用をサポートしており、RangeInputField もこの伝統を保持しています。

RangeInputField は 3 セットのプロパティを定義します。

$attributeFromと$attributeToはCModelで使用されており、CHtmlのactiveXXXメソッドを使うと、activeXXXでテキストボックスのラベルとテキストボックスを自動生成することができます。

プロパティ $nameFrom、$nameTo、$valueFrom、$valueTo プログラマはテキスト ボックスのラベルを自分で定義できます。

Yii アプリケーションのデフォルトのディレクトリ構造によれば、新しく作成された RangeInputField は protected/components ディレクトリに配置されるので、 protected/components/RangeInputField.php を作成します

class RangeInputField extends CInputWidget{public $attributeFrom;public $attributeTo;
public $nameFrom;public $nameTo;
public $valueFrom;public $valueTo;
function run(){if($this->hasModel()){
echo CHtml::activeTextField($this->model,
$this->attributeFrom);echo ' -> ';
echo CHtml::activeTextField($this->model,
$this->attributeTo);}else{echo CHtml::textField($this->nameFrom,$this->valueFrom);
echo ' -> ';echo CHtml::textField($this->nameTo,$this->valueTo);}}
/*** @return boolean whether this widget
* is associated with a data model.*/
protected function hasModel(){return $this->model instanceof CModel&& 
$this->attributeFrom!==null&& $this->attributeTo!==null;}}
ログイン後にコピー

このようにして、新しい UI コンポーネント RangeInputField がカスタマイズされ、リロードのみ run メソッドの代わりに、init は親クラスのメソッドを使用します。

これで、新しく作成したカスタム UI コンポーネント RangeInputField をテストできるようになります。この UI コンポーネントを使用するには、FormModel (CModel を使用) メソッドを使用します。

protected/models の下に RangeFrom.php を作成します

class RangeForm extends CFormModel{public $from;public $to;
function rules(){return 
array(array('from,to','numerical','integerOnly' =>true),
array(&#39;from&#39;,&#39;compare&#39;,&#39;compareAttribute&#39;=>&#39;to&#39;,&#39;operator&#39;=> &#39;<=&#39;,&#39;skipOnError&#39; => true),);}}
ログイン後にコピー

次に、デフォルトのコントローラーのデフォルトメソッドである、protected/controllers/siteController.php の actionIndex メソッドを変更します。

public function actionIndex(){$success=false;$model=new RangeForm();
if(!emptyempty($_POST[&#39;RangeForm&#39;])){$model->attributes=$_POST[&#39;RangeForm&#39;];if($model->validate()) $success=true;
}
$this->render(&#39;index&#39;, array(&#39;model&#39; => $model,&#39;success&#39; => $success,));}
ログイン後にコピー

対応する View を作成します

Success!
beginWidget(&#39;CActiveForm&#39;); ?>
errorSummary($model); ?>
widget(&#39;RangeInputField&#39;,array(&#39;model&#39;=>$model,&#39;attributeFrom&#39; => &#39;from&#39;,&#39;attributeTo&#39; => &#39;to&#39;,)) ?>endWidget(); ?>
ログイン後にコピー

この例を実行します

PHP 開発フレームワーク Yii Framework チュートリアル (10) UI コンポーネント カスタム コンポーネント

上記は、PHP 開発フレームワーク Yii Framework チュートリアル (10) UI コンポーネント カスタム コンポーネントの内容です。さらに関連する内容については、PHP に注目してください。中国語のウェブサイト (www.php .cn)!


ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート