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等等
控制器—-》父类控制器—-》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);
【数据查询延伸】
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 时间打,后加载
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 时间打,后加载
相关文章推荐
- Win7 iis配置ftp
- Yii2 高级版新建一个 Api 应用
- 分享几个基于 Yii2 的开源项目
- thinkphp3.2之模型(M层)
- PHP图片压缩的方法
- PHP图片压缩的方法
- 教你在Yii2.0框架中如何创建自定义小部件
- Yii2 自定义独立验证器
- Yii2 使用 Beanstalk 队列系统
- Yii2 注册表单验证规则 手机注册时候使用短信验证码
- Yii2 高级模板 多域名管理问题
- ThinkPHP - URL - 伪静态 - 路由 - 重写
- ThinkPHP - 配置项目结构
- 怎样配置PHP环境和安装Zendstdio编辑器
- PHP生成缩略图,控制图片质量,支持.png .jpg .gif
- PHP安全过滤函数
- yii2-lock-form 也许这就是你想要的,阻止表单多次提交
- PHP---正则表达式
- PHP日期与时间戳转换
- PHP/Yii2操作Cookie,常见问题以及注意事项