Yii框架学习笔记之应用组件操作示例
时间:2022-07-27
本文章向大家介绍Yii框架学习笔记之应用组件操作示例,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
本文实例讲述了Yii框架学习笔记之应用组件操作。分享给大家供大家参考,具体如下:
所有的组件都应声明在config/web.php
//组件声明在该数组下
'components'= array(
//自定义组件1 - 函数形式
'customComponent1' = function(){
$custom = new appcomponentsCustomComponentrealizationCustomComponent1();
$custom- setName('谭勇');
$custom- setAge(22);
return $custom;
},
//自定义组件2 - 数组形式
'customComponent2' = array(
'class' = 'appcomponentsCustomComponentrelazationCustomComponent2'
'name' = '谭勇',
'age' = 22
),
//自定义组件 - 字符串形式
'customComponent3' = 'appcomponentsCustomComponentrealizationCustomComponent3'
),
如果只是在components 中声明了该组件,那么只有在首次调用的时候才会实例化这个组件,之后调用都会复用之前的实例。 如果你在bootstrap 数组中声明了这个组件,那么该组件会随着应用主体的创建而实例(也就是默认会被实例,而不是首次调用才会实例这个组件)。
//默认加载customComponent1 和 customComponent2 组件
'bootstrap' = array(
'customComponent1','customComponent2'
),
在应用目录下创建 components 目录
组件 CutomComponent
接口类 appcomponentsCustomComponentCustomComponent;
<?php
namespace appcomponentsCustomComponent;
interface CustomComponent
{
public function setName($name);
public function setAge($age);
public function getName();
public function getAge();
}
?
接口实现类 appcomponentsCustomComponentrealizationCustomComponent1
<?php
namespace appcomponentsCustomComponentrealization;
use appcomponentsCustomComponentCustomComponent;
class CustomComponent1 implments CustomComponent
{
public $name='勇哥';
public $age = '我的年龄';
public function setName($name)
{
$this- name = $name;
}
public function getName()
{
return $this- name;
}
public function setAge($age)
{
$this- age = $age;
}
public function getAge()
{
return $this- age;
}
}
?
customComponent2,customComponent3 我们都让他们与customComponent1 具有相同的代码。 那么我们怎么去调用这些组件呢?
namespace appcontrollershome;
use Yii;
use yiiwebController;
class IndexController extends Controller
{
public function actionIndex()
{
//组件customComponent1
echo Yii::$app- customComponent1- getName();
//组件customComponent2
echo Yii::$app- customComponent2- getName();
//组件customComponent3
echo Yii::$app- customComponent3- getName();
}
}
然后回过头看数组形式、函数形式、字符串形式的组件
//函数形式 - 这个很容易理解 实例化后设置属性值
function(){
$custom = new appcomponentsCustomComponentrealizationCustomComponent1();
$custom- setName('谭勇');
$custom- setAge(22);
return $custom;
},
//数组形式 - 它会实例化这个组件 之后设置属性值 注意这里设置属性值的方法 和 函数不一样,它是 $custom- name = '谭勇' , $custom- age = 22
array(
'class' = 'appcomponentsCustomComponentrelazationCustomComponent2'
'name' = '谭勇',
'age' = 22
),
//字符串形式 只知道会实例化这个组件,怎么注入属性值,这个不清楚支不支持
组件有什么作用?
如果你理解Java spring mvc 那么就不难理解组件的作用 可以作为服务层,数据访问层等等
更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。
- Oracle 11g R2 RAC 高可用连接特性 – SCAN 详解
- Spring boot · 链接池配置
- Linux下命令行图片格式转换
- 用SQL解一道有趣的数学题:Gauss和Poincare
- OpenSSL 转换证书格式
- 电子邮件服务器DKIM配置
- 自相矛盾:一个进程可以自成死锁么?
- 数据库安全·开发加密插件
- wordpress无法安装这个包。: PCLZIP_ERR_MISSING_FILE (-4) : Missing archive file 'C:WINDOWSTEMP/wordpress-4.
- 数据库安全·数据加密
- Medium网友开发了一款应用程序 让学习算法和数据结构变得更有趣
- 数据库安全·Token 认证
- 数据库安全·用户/角色认证
- 防止在训练模型时信息丢失 用于TensorFlow、Keras和PyTorch的检查点教程
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法