Yii + jQuery Mobile

 今年初忽然想找一个PHP Framework来学习, 选择了Yii下手, 意外的
    还算好上手, 最近在开发Mobile Web平台, 看到jQuery Mobile的效果很好
    , 决定将两个东西一起使用, 虽然有不少衝突需要花时间解决, 但是整体
    效果还不错 ; 当初在这版看到网友[aaroms]分享了Yii的教学, 确实帮到
    我不少, 以他的文章继续下去, 分享一些Yii的使用心得

    1.多国语言
        使用yiic webapp 建立专案后, 可以在protected内看到有资料夹
    messages, 在这裡面以资料夹做语言的区隔, 例如建立(zhtw),(enus),共
    两个资料夹, 接著建立相同名称的php档案分别存放这两个资料夹内, 例如
    login.php, 程式内容就是代码对应文字

    zhtw/login.php
    <?php
        return array(
           't_account'=>'帐号',
           't_password'=>'密码',
           't_required'=>'请勿空白'
        );
    ?>

    enus/login.php
    <?php
        retunr array(
           't_account'=>'Account',
           't_password'=>'Password',
           't_required'=>' Is Required'
        );
    ?>


    接著在config/main.php设定网站预设的语言, 使用Yii::app()->language
    例如:
    if(empty($_GET['lang'])){
        $lang = 'zhtw'; }
    else{
        $lang = $_GET['lang']; }
    Yii::app()->language = $lang;


    最后利用<?php echo Yii::t('login', "t_account");?>
    会根据使用者所选择的语言, 印出[帐号] or [Account]


    2.AJAX栏位检查
        在protected/models内存放自订的Form Class, 针对要使用的资料栏位
    , 可以设定AJAX的检查, 首先宣告会使用到的栏位, 以登入的表格来说明,


    例如在 LoginForm.php 中宣告[帐号], [密码]两个变数
    public account;
    public password;


    设定变数的检查条件, 这边先以[required 必填]做举例, message则是设定
    栏位空白时, 所要显示的错误讯息
    public function rules(){
        return array(
           array('account, password,', 'required',
             'message'=>'{attribute}'.Yii::t('login', "t_required")),
        );
    }
    这边错误讯息使用{attribute}, 会自动判断是哪个变数 (因为有account,
    password两个以上的变数), 当前端判断[帐号]空白时, 会显示
    [account请勿空白], {attribute}只能抓到变数的名称, 所以要另外设定
    文字标籤来做多国语言的显示


    接著是文字标籤的设定
    public function attributeLabels(){
        return array(
           'account'=>Yii::t('login', "t_account"),
           'password'=>Yii::t('login', "t_password"),
        );
    }
    设定完后, 原先的[account请勿空白]中的account就会根据语言做变化,
    例如变成[帐号请勿空白]


    在protected/controller中设定每个action(动作), 定义Model以及
    要显示的View, 例如
    public function actionLogIn()
    {
       $model = new LoginForm;

       $this->render('login',array('model'=>$model));
    }

    最后, 在protected/view/site/login.php, 利用Yii的语法产生form以及
    资料栏位, 像是text, password, radio, hidden ....等


    <?php
        $form=$this->beginWidget('CActiveForm', array(
                'id'=>'login-form',
                'enableClientValidation'=>true,
                'clientOptions'=>array(
                        'validateOnSubmit'=>true,
                )
        ));
    ?>
        <?php echo $form->textField($model,'account');?>
        <?php echo $form->error($model,'account'); ?>
        <input type="submit" value="submit">
    <?php $this->endWidget(); ?>

    在按下Submit送出的时候, 就会根据在LoginForm中的设定栏位检查条件
    去做检查, 并且透过 echo $form->error($model,'account')将设定好的
    错误讯息印出
    ----------------------------------------------------------------
    LoginForm的栏位检查条件function rules()中, 除了[required必填], 还有
    其他一些常用的检查条件

    A. 正规表示法
       array('account, password', 'match', 'pattern'=>'/^[A-Za-z0-9]{6,12}$/',
'message'=>Yii::t('login', "e_match")),

    B. 两个栏位资料比对(例如设定密码, 需要 [密码] & [确认密码] ),
       需要注意的是, 两个变数的位置
       array('password_confirm', 'compare', 'compareAttribute'=>'password',
'message'=>Yii::t('login', "e_pass")),

   其它的检查条件可以至yii\framework\validators中查看

 3.引入档案

        A.本机端

        CSS和Img及JS这些档案, 通常是放在专案的最外层, Yii建立好专案后,
    固定会有以下这些资料夹
        /assets
        /css
        /images
        /protected
        /themes
    CSS内设定的图片路径就照一般即可, 如果是在/protected内的档案要读取图
    片, 则使用下列语法取得专案的路径

    <img src="<?php echo Yii::app()->request->baseUrl; ?>/images/
         act/act_01.jpg">

    同理, CSS和JS也是这样引入, 通常CSS和JS会设定在layouts/main.php这个主
    样板内, 如果某些特殊页面需要不同的CSS和JS, 则在那个View档案中, 加入

        $baseUrl = Yii::app()->baseUrl;
        $cs = Yii::app()->getClientScript();
        $cs->registerScriptFile($baseUrl.'/js/yourscript.js');
        $cs->registerCssFile($baseUrl.'/css/yourcss.css');


        B.远端

        使用jQuery Mobile时, 如果要远端引入jQuery官网的jquery.mobile.js,
    在加上jquery.mobile.js需要配合指定版本的jquery.js, 会跟Yii内建的
    jquery.js衝突

        打开/protected/config/main.php, 在components这段程式码中加上
        'clientScript'=>array(
            'packages'=>array(
               'jquery'=>array(
                   'baseUrl'=>'http://code.jquery.com/',
                   'js'=>array('jquery-1.8.2.min.js'),
                   'coreScriptPosition'=>CClientScript::POS_HEAD
               ),
               jquery.mobile'=>array(
                   'baseUrl'=>'http://code.jquery.com/mobile/1.3.0/',
                   'js'=>array('jquery.mobile-1.3.0.min.js'),
                   'depends'=>array('jquery'),
                   'coreScriptPosition'=>CClientScript::POS_BEGIN
                )
             ),
         ),

        接著在layouts/main.php主样版中, 使用下列语法
        <?php
                $cs = Yii::app()->getClientScript();
                $cs->registerCoreScript('jquery');
                $cs->registerCoreScript('jquery.mobile');
        ?>

    4.样板

        专案建立时初始在layouts中会有column1.php, column2.php, main.php,
        预设使用的是column1.php, 此档案的程式码中可以看到

        <?php $this->beginContent('//layouts/main'); ?>
                ......
                ......
        <?php $this->endContent(); ?>

        表示是使用main.php

        A.一般网页

        一般的网页大部分就是由上而下分三个区块, 在layouts/main.php中
        <div class='header'></div>

        <?php echo $content;?>

        <div class='footer'></div>

        其中$content就是在controller各个action指定使用的View所产生的
        页面, 例如在siteController中

        public function actionLogIn()
        {
                $model = new LoginForm;
                $this->render('login',array('model'=>$model));
        }

        则会使用views/site/login.php来当作View

        B.jQuery Mobile

        jQuery Mobile的架构跟一般网页稍有不同, 可以在同一支Html档案中
        , 将整个网站的内容放进去, 以DIV做各页面的区块, 每个页面区块一
        样包含header, content, footer例如:

        <div data-role='page' id='login'>
                <div data-role='header'></div>
                <div data-role='content'></div>
                <div data-role='footer'></div>
        </div>
        <div data-role='page' id='news'>
                <div data-role='header'></div>
                <div data-role='content'></div>
                <div data-role='footer'></div>
        </div>

        纯静态页面时这样使用还不错, 但是需要后端程式做处理就不适合了,
        在Yii中的layouts/main.php 则变成

        <div data-role='page'>

                <div data-role='header'></div>

                <div data-role='content'>
                        <?php echo $content;?>
                </div>

                <div data-role='footer'>
                        [回首页][功能选单]
                </div>

                <?php $this->beginContent('//layouts/menu'); ?>
                <?php $this->endContent(); ?>
        </div>

        JQM(jQuery Mobile)的header和footer在使用手机浏览时, 会自动固定
        在上方及下方, 通常footer可能会放[回首页]和[功能选单], 而[功能选
        单]是共用的页面, 所以使用beginContnet来引入, menu.php的内容大约
        是:

        <div data-role='panel' data-position='right'>
                [登入]
                [申请会员]
                [最新消息]
        </div>
        则这个Menu区块会从右方往左边展开

        有些页面可能需要在下方有[分页Bar], 可以参考巴哈姆特手机版样式, 这
        时候就需要不同的主样版, 刚刚有提到controller预设是使用column1.php
        , 这时候需要额外设定class SiteController中宣告样版变数

        public $layout = 'column1';

        接著在指定的action中设定
        public function actionNews()
        {
                $this->layout = 'column_page';
        }

        则当页面为News时, 会使用column_page.php, 其他页面则是使用
        column1.php, 接著column_page.php再搭配main_page.php,
        main_page.php中的内容则变成

        <div data-role='page'>

                <div data-role='header'></div>

                <div data-role='content'>
                        <?php echo $content;?>
                </div>

                <div data-role='footer'>
                        <?php $this->beginContent('//layouts/page'); ?>
                        <?php $this->endContent(); ?>
                        [回首页][功能选单]
                </div>

                <?php $this->beginContent('//layouts/menu'); ?>
                <?php $this->endContent(); ?>
        </div>

        在footer中加入page.php产生分页功能的php, 这个分页Bar就会跟footer
        一起, 固定在页面的下方
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值