Yii Framework 开发教程(10) UI 组件 自定义组件
来源:互联网 发布:数控车床编程自学 编辑:程序博客网 时间:2024/06/11 19:03
在介绍Yii内置UI组件之前,先介绍一下如何自定义组件,这样也有助于理解CWidget的用法,自定义组件就是重载 CWidget的init() 和 run() 方法。
- class MyWidget extends CWidget
- {
- public function init()
- {
- // 此方法会被 CController::beginWidget() 调用
- }
- public function run()
- {
- // 此方法会被 CController::endWidget() 调用
- }
- }
本例通过扩展CInputWidget,定义一个值域输入UI组件-RangeInputField,也就是允许用户输入两个数字定义一个值域范围。CInputWidget 支持使用CModel或者直接使用变量,RangeInputField 也保留了这一传统。
RangeInputField定义了三组属性。
$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, 我们使用FormModel (使用CModel)的方法来使用这个UI组件。
在protected/models下创建RangeFrom.php
- class RangeForm extends CFormModel
- {
- public $from;
- public $to;
- function rules()
- {
- return array(
- array('from,to','numerical','integerOnly' =>true),
- array('from','compare','compareAttribute'=>'to',
- 'operator'=> '<=','skipOnError' => true),
- );
- }
- }
然后修改缺省Controller的缺省方法, protected/controllers/siteController.php 中 actionIndex 方法。
- public function actionIndex()
- {
- $success=false;
- $model=new RangeForm();
- if(!empty($_POST['RangeForm']))
- {
- $model->attributes=$_POST['RangeForm'];
- if($model->validate()) $success=true;
- }
- $this->render('index', array(
- 'model' => $model,
- 'success' => $success,
- ));
- }
创建对应的View
- <!--?php if($success) : ?-->
- Success!
- <!--?php endif ?--></pre>
- <div class="form"><!--?php $form=$this--->beginWidget('CActiveForm'); ?>
- <!--?php echo $form--->errorSummary($model); ?>
- <div class="row"><!--?php $this--->widget('RangeInputField',array(
- 'model'=>$model,
- 'attributeFrom' => 'from',
- 'attributeTo' => 'to',
- )) ?></div>
- <div class="row submit"></div>
- <!--?php $this--->endWidget(); ?></div>
- <pre>
- <!-- form -->
运行这个例子
本例下载
0 0
- Yii Framework 开发教程(10) UI 组件 自定义组件
- Yii Framework 开发教程(10) UI 组件 自定义组件
- Yii Framework 开发教程(21) UI 组件 自定义Captcha示例
- Yii Framework 开发教程(21) UI 组件 自定义Captcha示例
- Yii Framework 开发教程(22) UI 组件 Zii组件简介
- Yii Framework 开发教程(22) UI 组件 Zii组件简介
- Yii Framework 开发教程(11) UI 组件 ActiveForm示例
- Yii Framework 开发教程(12) UI 组件 ClipWidget示例
- Yii Framework 开发教程(13) UI 组件 ContentDecorator示例
- Yii Framework 开发教程(14) UI 组件 MaskedTextField示例
- Yii Framework 开发教程(15) UI 组件 MultiFileUpload示例
- Yii Framework 开发教程(16) UI 组件 StarRating示例
- Yii Framework 开发教程(17) UI 组件 TabView示例
- Yii Framework 开发教程(18) UI 组件 TextHighlighter示例
- Yii Framework 开发教程(19) UI 组件 TreeView示例
- Yii Framework 开发教程(20) UI 组件 Captcha示例
- Yii Framework 开发教程(11) UI 组件 ActiveForm示例
- Yii Framework 开发教程(12) UI 组件 ClipWidget示例
- 14年的计划
- Yii Framework 开发教程(9) UI 小组件Widget 概述
- 最长公共子序列
- 使用 Sandcastle 生成代码帮助文档
- [unity3d]unity平台的预处理
- Yii Framework 开发教程(10) UI 组件 自定义组件
- android surfaceflinger研究----显示系统
- SYMBOL DS6708 - USB虚拟串口
- XML
- Fifa Ultimate Team Millionaire Trading Center - Launching Now!
- MySQL判断表是否存在
- android应用开发揭秘第13章01示例,移动图像,opengl绘制星星问题解决!
- java.sql.Timestamp与java.util.Date的相互转换
- 淘宝u站推广—U站推广必用的框架代码和跳转