你现在的位置:首页 > PHP网站建设知识库 > Yii > 正文

yii开发技巧(1)

    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('jquery');  

    2. Yii isNewRecord 修复

    Yii 的 Model 的 isNewRecord 属性是很好用的,可以根据这个属性进行分情况讨论。但是,假如我们开启了事务机制或是其他情况,造成数据插入后又被回滚了,这时数据库里没有该条记录,但是 isNewRecord 是 flase,即认为已经不是新纪录了。解决方法是用主键去访问数据库,判断究竟是不是新纪录,而我们在用到这个属性之前要先按下面处理一下。以下 Model 是 Post,主键是 id:

if(!$model->isNewRecord)  
{  
    $db_exist = Post::model()->findByPk($model->id);  
    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();  
try  
{  
    /* 成功则 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();  
    }  
}