Yii Framework 开发教程(10) UI 组件 自定义组件

2023-11-09


在介绍Yii内置UI组件之前,先介绍一下如何自定义组件,这样也有助于理解CWidget的用法,

自定义组件就是重载 CWidget的init() 和 run() 方法。

  1. class MyWidget extends CWidget  
  2. {  
  3.     public function init()  
  4.     {  
  5.         // 此方法会被 CController::beginWidget() 调用  
  6.     }  
  7.   
  8.     public function run()  
  9.     {  
  10.         // 此方法会被 CController::endWidget() 调用  
  11.     }  
  12. }  
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

  1. class RangeInputField extends CInputWidget  
  2. {  
  3.     public $attributeFrom;  
  4.     public $attributeTo;  
  5.   
  6.     public $nameFrom;  
  7.     public $nameTo;  
  8.   
  9.     public $valueFrom;  
  10.     public $valueTo;  
  11.   
  12.     function run()  
  13.     {  
  14.         if($this->hasModel())  
  15.         {  
  16.             echo CHtml::activeTextField($this->model,  
  17.                 $this->attributeFrom);  
  18.             echo ' -> ';  
  19.             echo CHtml::activeTextField($this->model,  
  20.                 $this->attributeTo);  
  21.         }else  
  22.         {  
  23.             echo CHtml::textField($this->nameFrom,  
  24.                 $this->valueFrom);  
  25.             echo ' -> ';  
  26.             echo CHtml::textField($this->nameTo,  
  27.                 $this->valueTo);  
  28.         }  
  29.     }  
  30.   
  31.     /** 
  32.      * @return boolean whether this widget 
  33.      * is associated with a data model. 
  34.      */  
  35.     protected function hasModel()  
  36.     {  
  37.         return $this->model instanceof CModel  
  38.             && $this->attributeFrom!==null  
  39.             && $this->attributeTo!==null;  
  40.     }  
  41. }  
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

  1. class RangeForm extends CFormModel  
  2. {  
  3.     public $from;  
  4.     public $to;  
  5.   
  6.     function rules()  
  7.     {  
  8.         return array(  
  9.             array('from,to','numerical','integerOnly' =>true),  
  10.             array('from','compare','compareAttribute'=>'to',  
  11.                     'operator'=> '<=','skipOnError' => true),  
  12.         );  
  13.     }  
  14. }  
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 方法。

  1. public function actionIndex()  
  2. {  
  3.     $success=false;  
  4.     $model=new RangeForm();  
  5.   
  6.     if(!empty($_POST['RangeForm']))  
  7.     {  
  8.         $model->attributes=$_POST['RangeForm'];  
  9.   
  10.         if($model->validate()) $success=true;  
  11.   
  12.     }  
  13.   
  14.     $this->render('index'array(  
  15.             'model' => $model,  
  16.             'success' => $success,  
  17.             ));  
  18. }  
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

  1. <!--?php if($success) : ?-->  
  2.   
  3. Success!  
  4.   
  5. <!--?php endif ?--></pre>  
  6. <div class="form"><!--?php $form=$this--->beginWidget('CActiveForm'); ?>  
  7.   
  8.  <!--?php echo $form--->errorSummary($model); ?>  
  9. <div class="row"><!--?php $this--->widget('RangeInputField',array(  
  10.  'model'=>$model,  
  11.  'attributeFrom' => 'from',  
  12.  'attributeTo' => 'to',  
  13.  )) ?></div>  
  14. <div class="row submit"></div>  
  15. <!--?php $this--->endWidget(); ?></div>  
  16. <pre>  
  17. <!-- form -->  
<!--?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 -->

运行这个例子

201212122003

本例下载

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Yii Framework 开发教程(10) UI 组件 自定义组件 的相关文章

随机推荐

  • HashMap工作原理

    HashMap是一个key value键值对的数据结构 它是由数组 链表 红黑树的形式实现的 默认长度是16 只能有一个key为null 可以有多个value为null 数组是一个个Node 数组 我们叫它hash桶数组 它上面存放的是ke
  • 上采样方法

    目录 上采样 Upsampling 方法 去池化 最近邻方法 钉床方法 最大去池化 双线性插值 反卷积 膨胀卷积 上采样 Upsampling 方法 上采样 是指将低分辨率的图像或特征图放大到原始分辨率的过程 在计算机视觉中 上采样通常用于
  • Bug的级别,按照什么划分

    Bug分类和定级 一 bug的定义 二 bug的类型 三 bug的等级 四 bug的优先级 一 bug的定义 一般是指不满足用户需求的则可以认为是bug 狭义指软件程序的漏洞或缺陷 广义指测试工程师或用户提出的软件可改进的细节 或与需求文档
  • CodePush 私有化部署

    安装 NodeJs 和 Npm 下载安装 NodeJs 安装 nodejs wget https nodejs org dist v6 9 4 node v6 9 4 tar gz configuremakemake install 安装
  • SIM卡与IEC 7816

    SIM卡与IEC 7816 SIM Subscriber Identification Module 又被称为用户身份识别卡 智能卡 SIM卡是一种物理载体 而相关的性能以及协议的规定都包含在IEC 7816协议中 IEC 7816规范 物
  • HJ103 Redraiment的走法 —— 华为机考练习题

    一 题目 描述 Redraiment是走梅花桩的高手 Redraiment可以选择任意一个起点 从前到后 但只能从低处往高处的桩子走 他希望走的步数最多 你能替Redraiment研究他最多走的步数吗 数据范围 每组数据长度满足 1 le
  • ag-grid-vue的配置

    public get gridOptions GridOptions const that this return headerHeight 30 表头高度 rowHeight 30 行高 columnDefs 列定义 headerName
  • 常用JS对象的方法总结

    String 方法 描述 charAt 返回在指定位置的字符 charCodeAt 返回在指定的位置的字符的 Unicode 编码 concat 连接字符串 indexOf 检索字符串 match 找到一个或多个正则表达式的匹配 repla
  • spring的后处理

    什么是spring的后处理器 spring的后处理是spring对开开发的重要扩展点 bean的许多的功能的增强就是通过后处理实现的 他可以允许我们产于到bean的实例化路程中去 两类后处理器 根据我们对于bean的实例化的认识 我们知道b
  • C中调用带参数的exe并接收返回值

    test exe c sharp view plain copy include
  • 高等数学知识点总结

    高等数学知识点总结 一 间断点 定义 1 f x 在处没有定义 则为间断点 2 f x 在处有定义 但是极限不存在 3 f x 在处有定义 极限也存在 但是不相等 分类 第一类间断点 左右极限都存在 1 可去间断点 2 跳跃间断点 第二类间
  • Android Service

    http www cnblogs com lwbqqyumidi p 4181185 html Service通常总是称之为 后台服务 其中 后台 一词是相对于前台而言的 具体是指其本身的运行并不依赖于用户可视的UI界面 因此 从实际业务需
  • 微信小程序使用wxParse解析html

    转 http www jianshu com p 3de027555e77 最近项目上遇到在微信小程序里需要显示新闻内容 新闻内容是通过接口读取的服务器中的富文本内容 是html格式的 小程序默认是不支持html格式的内容显示的 那我们需要
  • 内存管理<原理篇>(四、分段和分页)

    文章目录 4 1 分段 4 1 1 程序段介绍 4 1 2 各段放入内存信息 4 1 3 段表 4 1 4 总结 4 2 分页 4 2 1 概念介绍 4 2 2 各段加载进内存 4 2 3 例子分析 4 2 4 总结 4 1 分段 在上一篇
  • python 使用 passlib 库在 windows 平台实现 crypt

    今天同步代码的时候 发现别的同事往项目里新加了一行 import crypt 编译器提示有错 我就去检查了项目的requirements文件 但没找到新的依赖 然后我google了一下 原来这个文件是Unix 系统用来给密码加密的文件 并不
  • Coding pages 不见了

    Coding pages 不见了 起因 因为自己的这个博客 有时候访问还是比较慢的 原因是我的代码是在GitHub上托管的 GitHub是国外的网站 服务器都在国外 所以访问速度就特别慢 我就想找国内的既能实现代码托管 又能生成静态网页的平
  • Java实现方法中基本类型参数按地址传递

    参考了网上的一些资料 自己总结了一下 详细的可以去以下的博主看看 https www cnblogs com lixiaolun p 4311863 html http blog csdn net maoyeqiu article deta
  • 白话机器学习-Transformer

    一 背景 大抵是去年底吧 收到了几个公众号读者的信息 希望能写几篇介绍下Attention以及Transformer相关的算法的文章 当时的我也是满口答应了 但是确实最后耽误到了现在也没有写 前一阵打算写这方面的文章 不过发现一个问题 就是
  • 一组整数的全排列【C程序】

    include iostream using namespace std int myfactorial int n int i factorial i 1 factorial 1 while i lt n factorial factor
  • Yii Framework 开发教程(10) UI 组件 自定义组件

    在介绍Yii内置UI组件之前 先介绍一下如何自定义组件 这样也有助于理解CWidget的用法 自定义组件就是重载 CWidget的init 和 run 方法 php view plain copy print class MyWidget