yii中常见问题(2)

如何显示静态页 重写actions ‘help’=>array( ‘class’=>’CViewAction’, ‘basePath’=>’help’, //指定目录名 ‘defaultView’=>’default’, ‘viewParam’=>’help’ //get参数 ), 假定当前控制器是post 那么可以能过/post/help/help/content访问help目录下的content.php 可以建立子目录比如help/reigterhelp/content.那可以通过/post/help/help/registerhelp.content来访问 用CViewAction的好处时,可以与其它的view共享layout

多对多关联条件 $criteria->addInCondition(“categorys.id”,$in); $criteria->addSearchCondition(‘Shop.name’,$keyword); $shops=Shop::model()->with(array(“categorys”=>array(‘together’=>true)))->findAll($criteria); 同时要在Shop模型中加入alias=”categorys” ,另外together=true放在模型的关联中也可

YII中的RBAC权限,用数据库存item, 在system/web/auth下找到相应的sql导放到数据库中 配置’authManager’ => array( ‘class’ => ‘CDbAuthManager’, ‘connectionID’ => ‘db’, ), 如果在sql中导入的三个表的表名不是默认的,需要在这上边的配置中配置,具体的看api $auth=Yii::app()->authManager; //$auth->createOperation(“post”,’postpost’); //$auth->createTask(“post”,”posts”); $auth->createRole(“post”,”post”); auth->assign(“post”,’demo’); if(Yii::app()->user->checkAccess(“post”)){ echo “yes”; else{ echo “no”; } 这种情况下三者是一样的

如何获得上一页的url以返回 Yii::app()->request->urlReferrer;

在一对多,多对多查询时,the eager loading 联合所有的表生成一条语句,如果主表有limit的查询选项,那么他将单独执行,然后再执行与关联表有关的语句,返回相关表的数据对象,这就是为什么在做大优惠时,以中间表为查询条件出错的原因,解决办法 with()返回 CActiveFinder对象,其方法together(),既使主表中有LIMIT/OFFSET 也是返回一条sql; 多对多查询时,分页有时候页中显示的条数不正确,因为有重复的项,加上$criteria->group = true即可

COutputCache 即是一个组件,又是一个filter,前者的时候用于在view中缓存内容,后者的时候用于在controller中缓存 就是说片段缓存,是把COutputCache当一个widget来用,页面缓存把COutputCache当作一个filter来用 动态缓存,用CController的一个方法 renderDynamic($callback);

如何在程序有错的时候跳到指定的action 在components中设置 ‘errorHandler’=>array( ‘errorAction’=>’site/error’, ), 在此action中可以能过Yii::app()->errorHandler->error获得错误信息

把字符串分解成数组,并去掉空值 preg_split(‘/\s*,\s*/’,’this , is , , a test’,-1,PREG_SPLIT_NO_EMPTY )

CActiveRecord::exits();判断有没有这样的记录,一般用于添加时,判断某字段有没有重复

CActiveDataProvider 一个基于ActiveRecord的数据提供源 常用的用法 $dataProvider=new CActiveDataProvider(‘Post’, array( ‘criteria’=>array(), ‘pagination’=>array(), ‘sort’=>array(), )); 上如’sort’=>array( ‘defaultOrder’=>’status, update_time DESC’, ),

ClistView同上结合使用,其中的_view中可以用一个$data的变量,代表当前的model数据 如果dataProvider中的pagination,sort设为false,则CliveView中对应的部分也无法使用 $this->widget(‘zii.widgets.ClistView’,array( ‘dataProvider’ => $dataprovider, ‘itemView’ => ‘_view’, ‘template’ => ‘{items}{sorter}{pager}’, ‘sortableAttributes’ => array( ), ));

插入meta信息 Yii::app()->clientScript->registerMetaTag(‘keywords’,’关键字’); Yii::app()->clientScript->registerMetaTag(‘description’,’一些描述’);

CMap::mergeArray() 比array_merge更智能的合并数组,yii中配置的合并用这个

CClipWidget 通过ob_start ob_getconent生成一段不显示的内容,可以能过CController::clips访问,如 $this->beginWidget(‘CClipWidget’,array(‘id’=>’name’,’renderClip’=>true)); 可以通过$this->clips['name']来显示,其中的renderClip如果为false,则在当前位置不显示内容 如果在Model一次验证多个属于,显示不同的内容?如下 [后来发现这个不起作有] return array( array(‘title, content’, ‘required’, ‘message’=>’Please enter a value for {attribute}.’), // … other rules );

获得服务器时间 $_SERVER['REQUEST_TIME'] 维护程序时,这样子所有的请求转发到一个地方 ‘catchAllRequest’=>array(‘site/all’),

根据二级域名缓存 array( ‘COutputCache + search’, ‘duration’ => 120, ‘varyByParam’ => array(‘q’,’page’), ‘varyByExpression’ => “app()->request->hostInfo”, ),

有多个分站时,同步登陆,基本于cookie ‘user’=>array( ‘identityCookie’=>array(‘domain’=>’.dayouhui.com’), ‘allowAutoLogin’ => true, ) 如果是基本于session ‘session’ => array( ‘cookieParams’ => array(‘domain’ => ‘.dayouhui’, ‘lifetime’ => 0), ‘timeout’ => 3600, ), 如何使用theme 在main.php中配置 ‘theme’=>’classic’, 如何得到前前使用的主题 Yii::app()->theme 得到名子 Yii::app()->theme->name; themes文件夹和protected是同级的,其下边某个theme的目录结果同protected/views下一样

关于skin 用theme改变view的外观,skin是用来改变widgets的外观的 skin是健值对用于初始化一个widget的属性 要对widget使用skin,需要做以下几步 1:配置’widgetFactory’=>array( ‘enableSkin’=>true, ), 2:在views下建立skins目录 3:在skins目录下建立与Widget名子一样的php文件,返回数组,即能用于widget的初始配置 4:在php文件中,如果有defautl的配置,会先找这个skin 5:如果应用了theme,程序会先去对应的theme目录下的skins中找配置文件 6:如果只是想给widget统一一个skin,建议用Customizing Widgets Globally

如果防止post跨站攻击 ‘request’=>array( ‘enableCsrfValidation’=>true, ), 这时候生成的表单要用CHtml::form(),其会写一段代码在cookie中 防止Cookie攻击 ‘request’=>array( ‘enableCookieValidation’=>true, ), 同时生成与得到cookie是要用 CHttpCookie

如何让表单验证不驼过的提示为中文 在main.php的配置中加上 ‘language’ => ‘zh_CN’, 如何实现仿google的自动完成功能

<?php $this->widget(‘CAutoComplete’, array( ‘name’=>’xxx’, ‘url’=>array(‘suggestTags’), ‘multiple’=>false, ‘htmlOptions’=>array(‘size’=>50), )); ?>

然后在url指定的地址中的方法中如下输出,即可 echo “a\nb\nc”

//CGridView详解 这东西在后台比较有用,能加速开发的速度,值得一看 CGridView用表格的方式显示数据项 每一行代表一个数据项,一列通常代表数据项的一个属性 CGridView支持排序和分页,可以用ajax或普通的方式 CgridView必序和data provider一起使用 最简单的用法 $dataprovider = new CActiveDataProvider(‘Post’); $this->widget(‘zii.widgets.grid.CGridView’,array( ‘dataProvider’=>$dataprovider, )); 这会用表格的方式显示每一条数据项,每一列是Post的一个属性 在显示中带了分页和排序 我们可以自定义CgridView::columns属性,以自定义表格列的显示方式 这个cloumns如何配置呢? 其是一个数组,每一个数组元素对应着一列的配置,可以是字符串或数组 1、如果是字符串,格式是name:type:header 后两者是可选的,根据这三个值,创建一个CdatColumn实例 其中type参见CFormatter 2、如果是数组,其可以实例化CDdataColumn、ClinkColumn,CButtonColumn,CCheckBoxColumn实例,具体实例化哪个 由数组中的class指定,默认是CDataColumn 2.1,如果class=>’CDataCloumn’ 则可以指定name或者value,如果指定以value优先 用CDataColumn时如何以关联表的数据序列? 代码如下:表示可以post关联的author中的username排序列 $dataprovider = new CActiveDataProvider(‘Post’,array( ‘criteria’=>array( ‘with’=>’author’, ), ‘sort’=>array( ‘attributes’=>array( ‘title’,’create_time’, ‘author_id’=>array(‘asc’=>’author.username asc’,’desc’=>’author.username desc’,’label’=>’作者’) ) ), )); $this->widget(‘zii.widgets.grid.CGridView’,array( ‘dataProvider’=>$dataprovider, ‘columns’=>array( ‘title’, ‘create_time’, array(‘name’=>’author_id’,’value’=>’$data->author->username’), ), )); 另外CDataColumn还有一个filter属性,如果是空,那么生成一个textfield,如果是数组(键值),则生成一个dropDownlist在当前列的上部,供搜索 2.2:如果class=>”CLinkColumn” array(‘class’=>’CLinkColumn’,’label’=>’查看用户’,’url’=>Yii::app()->createURL(‘user/edit’)) 则生成一个连接 2.3:如果class=”CCheckBoxColumn” array(‘class’=>’CCheckBoxColumn’,’name’=>’title’,’id’=>’select’), 可以生成一个checkbox供选择,且只能选一个 可以配置CGridView::selectableRows 如果是0,则不能选,如果 1,只选一个如果是2或其它值,则可以选多个 代码如下: $this->widget(‘zii.widgets.grid.CGridView’,array( ‘dataProvider’=>$dataprovider, ‘selectableRows’=>2, ‘columns’=>array( array(‘class’=>’CCheckBoxColumn’,’name’=>’title’,’id’=>’select’), ), 2.3:如果class=”CButtonColumn” array( ‘class’=>’CButtonColumn’, ‘updateButtonUrl’=>’Yii::app()->createUrl(“post/edit”,array(“id”=>$data->id));’, ), 修改updateButtonUrl为编辑贴子 如何用gridview生成一个代搜索的管理列表 1、在Model的rules 设定可以搜索的属性 array(‘title, status, create_time’, ‘safe’, ‘on’=>’search’), 2、在Model中,添加搜索时的方法 public function search() { $criteria=new CDbCriteria; $criteria->compare(‘title’,$this->title,true); $criteria->compare(‘status’,$this->status); $criteria->compare(‘create_time’,$this->create_time); return new CActiveDataProvider(‘Post’, array( ‘criteria’=>$criteria, ‘sort’=>array( ‘defaultOrder’=>’status, update_time DESC’, ), )); } 3、 在Controler中,写接受搜索用到的表单的值的方法 public function actionAdmin() { $model=new Post(‘search’); if(isset($_GET['Post'])) $model->attributes=$_GET['Post']; $this->render(‘admin’,array( ‘model’=>$model, )); } 4、在view中用CGridView显示 设置好

<?php $this->widget(‘zii.widgets.grid.CGridView’, array( ‘dataProvider’=>$model->search(), ‘filter’=>$model, ‘columns’=>array( ), )); ?>

以上代码大部分是yii自动生成的,只要做少量修改即可 有时候会出现,搜索后页面为空的清况,原因可能是 layout/main.php中 echo $content外层无div,就是说main.php中必须有一个div包含$content

转载于:https://my.oschina.net/u/925485/blog/162570

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值