首页 > 编程 > PHP > 正文

PHP的Yii框架使用中的一些错误解决方法与建议

2020-03-22 19:12:31
字体:
来源:转载
供稿:网友
此文意在记录 Yii 开发过程中的小问题解决方案,不全面,不权威,不是教程。自己写过,觉得可以解决问题,以后也可能用上,就记记吧。 1. Yii 中 Js 和 Css 文件的引入。
我们就从最简单的问题开始吧,说起来也不是问题,只是语法罢了。假设我们的 js 文件都放在和 protected 同一层的 js 文件夹里,css 文件都放在和 protected 同一层的 css 文件夹里,好吧,规范就是这样的...那我们可以在对应的 view 界面按下面这样写,css 和 js 函数的参数是不同的哦...(之前因为这个调了一个小时..)
注册 js 文件的第二个参数是 js 所放的位置,可选三个:CClientScript::POS_HEAD 放在 Head 部分 CClientScript::POS_BEGIN 放在 Body 开始处 CClientScript::POS_END 放在 Body 结束处,没有特别要求就不用填了...注册 Css 文件的第二个参数是 media,,有兴趣的同学点这里,目前还是默认就好...
对于 Jquery 这样的 js ,用 registerCoreScript 不会造成莫名奇妙的错误...//注册 js 文件 Yii::app()- clientScript- registerScriptFile(Yii::app()- baseUrl.'/js/project1.js',CClientScript::POS_HEAD); //注册 css 文件 Yii::app()- clientScript- registerCssFile(Yii::app()- baseUrl.'/css/project1.css'); //注册 Jquery 文件 Yii::app()- clientScript- registerCoreScript('html' target='_blank'>jquery'); 2. Yii isNewRecord 修复
Yii 的 Model 的 isNewRecord 属性是很好用的,可以根据这个属性进行分情况讨论。但是,假如我们开启了事务机制或是其他情况,造成数据插入后又被回滚了,这时数据库里没有该条记录,但是 isNewRecord 是 flase,即认为已经不是新纪录了。解决方法是用主键去访问数据库,判断究竟是不是新纪录,而我们在用到这个属性之前要先按下面处理一下。以下 Model 是 Post,主键是 id:if(!$model- isNewRecord) $db_exist = Post::model()- findByPk($model- if($db_exist == NULL) $model- isNewRecord = true;
3.Yii 生成 隐藏输入域
虽然自己写一个输入域很容易(不就是 display:none 嘛),但是有时架不住需要按照 Yii 的表单代码格式呀,反正就一句话... php echo $form- hiddenField($model,'name'); php if($model- isNewRecord) echo $form- hiddenField($model,'path',array('size'= 60,'maxlength'= 128,'id'= 'path1')); 4. Yii 生成下拉菜单
很多时候我们在 form 里需要一个下拉菜单,这时候 Chtml 的 listdata 就很好用的。假如我们数据库里的字段只有很少的可能,比如 0 和 1,可以按下面写:
echo $form- dropDownList($model,'is_marry',array('0'= '否','1'= '是')); 这时候,你看到的就是 是 和 否 的下拉菜单,选择 '是' 提交的时候这个字段填的就是 1 ,'否' 就是 0 。当然,经常不只这么简单,我们可以在 Model 里面添加一个函数用于生成下拉菜单的数组,然后在 view 里去调用就行了。这个函数的数据可以自己写的,或者在数据库查找得来的。下面用了 listdata, 具体意思是以 model 中 id 为 键, name 为值。/* 写在 model 里 */ public function getUserOptions() $models = User::model()- findAll(); $models = User::model()- findAllByAttributes(array('is_regeister'= '1')); return CHtml::listdata($models, 'id', 'name'); /* 写在 view 的界面里 */ echo $form- dropDownList($model,'user_id',User::model()- getUserOptions());
5.Yii 开启事务机制
在你同时保存几条记录到数据库时,你可能很有必要开启事务机制。Yii 开启事务机制很容易,只要三句话就够了。/*开启事务机制*/ $transaction = Yii::app()- db- beginTransaction(); /* 成功则 commit */ $transaction- commit(); catch(Exception $e) $transaction- rollBack(); 比较完整的像这样:
if($_POST['ModelA']) /*开启事务机制*/ $transaction = Yii::app()- db- beginTransaction(); try /*此处省略一堆逻辑*/ $modelA- save(); $modelB- save(); /* 成功则 commit */ $transaction- commit(); $this- redirect(array('view','id'= $model- id)); catch(Exception $e) $transaction- rollBack(); 不过我一般会像下面这样,有什么好处请自行体会...if($_POST['ModelA']) /*开启事务机制*/ $transaction = Yii::app()- db- beginTransaction(); try $validated = true; /*此处省略一堆逻辑*/ $valid = $modelA- save(); $validated = $valid & $validated; /*此处继续省略一堆逻辑*/ $valid = $modelB- save(); $validated = $valid & $validated; /* 成功则 commit */ if($validated) $transaction- commit(); $this- redirect(array('view','id'= $model- id)); else /*不成功即回滚 */ $transaction- rollBack(); catch(Exception $e) $transaction- rollBack(); 6.关联表查询相同字段出错。
有时候我们建了两个表,但是两个表有相同的字段,在用 CDbCriteria 进行 with 关联查询搜索时候,如果没有进行额外设置,那会出现查询错误,大概的意思就是 Mysql 语句模糊。这时候,我们在主表设置一个别名就好了,然后查询相关字段的时候注意把 名字加上就行。

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表