您的位置:首页 > 编程语言 > PHP开发

yii 知识点

2016-02-04 17:41 591 查看
YII框架讲解

Yii::app() 是CwebApplication类实例化的对象

CwebApplication(framework/web/CwebApplication.php)

因此Yii::app()可以调用CwebApplication 或父类 CApplication

我们可以通过Yii::app() 调用系统的组件

User session request log db等等

在系统的任何角落都可以直接访问以上组件
Yii ::app()->user  (实例化对象'CWebUser' => '/web/auth/CWebUser.php',)


控制器—-》父类控制器—-》compoments—main.php—-index.php

main.php中import可引入组件,model,module等



render 和renderpartial之间最大的区别就是:一个是渲染模板,一个不渲染模板。

其中render 输出父模板的内容,将渲染的内容,嵌入父模板即layout文件夹中文件。

renderPartial 则不输出父模板的内容。只对本次渲染的局部内容

gii模块如何来访问:先判断是否是模块名是的话直接找,不是的话去找控制器

通过路由形式访问该模块

http://web.0507shop.com/index.php?r=模块名字

http://url/index.php?r=gii







框架里model就是一个类,属性就是数据表的字段





yii模块中module可以调用 前台model,所以在前台写即可

yii AR模型

goodsmodel=Goods::model();//只挑出一条记录goods_model = Goods::model();
//只挑出一条记录
goods_info = goodsmodel−>find();//获得全部商品信息,是一个大的数组,里面有具体对象元素,遍历出来结果是每条记录对象goods_model->find();
//获得全部商品信息,是一个大的数组 ,里面有具体对象元素,遍历出来结果是每条记录对象
goods_info = $goods_model->findAll();

SELECT * from one_table where username = ‘admin’ and password = ‘123456’;

对应的AR model查询如下

Admin::model()->findAllByAttributes(array(‘username’=>’admin’, ‘password’=>’123456’));

通过具体sql语句获得信息】

AR:findAllBysql();

操作数据库增删改通过模型创建对象来操作,

对象调用 相关方法实现操作即原生的new对象来

我们使用模型model步骤:

1.创建模型对象

①模型名字::model()

②new 模型模型()

2.利用对象调用模型里边的一些方法,实现对数据的操作

表单展现:model

attributeLabels() 模型属性与汉字标签名字对应

new Goods() 和 Goods::model()

都可以进行查询

前者主要是在添加的时候使用,后者是在查询或修改的时候使用。

切记

function actionUpdat(id,id,name,tp){
//除了添加数据都使用Goods::model()实例化对象tp){
//除了添加数据都使用Goods::model()实例化对象
goods_model = Goods::model();

//goodsmodel−>updateByPk(goods_model->updateByPk(id,array(‘goods_name’=>’龙龙龙龙’),condition,condition,params);

goodsinfo=goods_info = goods_model->findByPk($id);

//修改的时候,
//创建数据模型model对象
//new Good():调用save()方法执行insert语句
//Goods::model() 调用save()方法时执行update语句
if(isset($_POST['submit'])){
foreach($_POST['Goods'] as $k=> $v){
$goods_info->$k = $v;
}
$goods_info->save();
}

$this ->renderPartial('update',array('goods_model'=>$goods_info));
}


【数据查询延伸】

AR(CActiveRecord)活跃记录

find() 查询一个信息

findByPk 根据主键查询信息

findBySql根据sql语句查询信息

findAll()查询全部信息

findAllByPk 根据主键查询全部信息

findAllBySql根据sql语句查询全部信息

findBySql 和 findAllBySql

根据sql语句查询信息,前者会查询一条记录信息,后者会查询条记录信息

前者给返回一个数据模型对象,后者以数组形式给我们返回多个数据模型对象

select * from goods limit 10

findByPk 和 findAllByPk

都是根据主键进行信息的查询

前者每次只可以传递一个主键信息,后者可以传递一个也传递多个

后者传递参数,如果是多个主键信息,需要以数组形式给我们传递。



select condition order limit offset 都是从哪来的。

AR需要最终转变为具体的sql语句,通过一个中间类(criteria标准)协助转为的具体sql语句,上边的关键字就是这个中间类criteria的一些属性。



usermodel−>attributes=user_model -> attributes = _POST[‘User’];

attributes这个属性在使用的时候会收集表单信息并赋予模型属性里边

该属性是和rules()方法一并使用,只有在rules()里边设置了验证规则的属性才可以被attributes接收

如果有的属性没有具体验证规则,则给一个safe规则。







【用户退出系统同时删除session和cookie】

Yii ::app()->user->logout() ;

【如何获得当前控制器和方法】

//当前控制器user

echo this−>id;//当前方法loginechothis->id;
//当前方法login
echo this->action->id









Duration、varyByParam、dependency这个几个属性在哪?

System.web.widgets.CoutputCache.php

我们是否可以在布局进行页面缓存

答:理论上不可以,视图先加载,布局后加载

视图:0.05135800 1369315232 时间小,先加载

布局:0.05197600 1369315232 时间打,后加载
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: