YIIFramework 1.1.2版本中已经有了gii,
就是一个基于web的脚手架!可以生成模型,控制器,视图等!
一、配置
配置protected/config/main.php
'modules'=>array(
'gii'=>array(
'class'=>'system.gii.GiiModule',
'password'=>'123456',
//'ipFilters'=>array('192.168.1.101'),
//如果用IP访问,这里需配置相应的IP
),
),
我们可以通过以下链接来访问: /index.php?r=gii
尽管默认的代码生成器已经可以产生很强大的代码,我也经常希望能定制他们或者创建个新的来满足我们的需求,例如,我们希望生成的代码能符合我们的编码风格,或者我们希望代码能支持国际化,这些都可以轻松的通过Gii实现 Gii 可以通过两种模式进行扩展:定制代码模板来扩展已有的代码生成器,和编写新的代码生成器。
Gii 通过GiiModule::generatorPaths属性设置的路径搜索可用的代码生成器。如果需要定制,我们可以在应用的配置中如下配置这个属性。
'gii' => array(
'class' => 'system.gii.GiiModule',
'password' => '123456',
'generatorPaths'=>array( 'application.gii'), //除了在默认的system.gii.generators之外,还在路径别名为application.gii的目录下检索可用的代码生成器
),
有可能会在不同的目录底下有相同名字的代码生成器,这种情况下在GiiModule::generatorPaths中最先指定的,具有优先权。
我们首先创建一个名为protected/gii/model/templates/compact的路径。这里的model意味着我们要重写摩尔恩的model代码生成器。templates/compact 表示我们要添加一个新的代码模板,名字为compact,然后我们修改应用的配置,把application.gii加入到 GiiModule::generatorPaths中,如同上面所叙现在打开model代码生成器页面。点击代码模板字段,在出现的下拉框里我们能看到我们新加的模板路径compact,如果我们选择这个模板来生成代码,我们会看到一个错误,那是因为我们还没有在compact底下放入任何的实际代码模板。
下面开始我们真正的自定义的工作。打开文件protected/gii/model/templates/compact/model.php进行编辑。记住这个文件会像被作为视图文件使用,这意味着它可以包含PHP语句和声明。让我们修改模板,以便生成器产生的attributeLabels()方法,使用YII::t()来对标签支持国际化。
public function attributeLabels()
{
return array(
<?php foreach($labels as $name=>$label): ?>
<?php echo "'$name' =>YII::t('application', '$label'),\n"; ?>
<?php endforeach; ?>
);
}
在每一个代码模板,我们可以访问一些预定义的变量,例如上面例子中的$labels。这些变量由相应的代码生成器产生。不同的代码生成器在他们各自的模板中可能产生不同的变量。请仔细阅读默认代码模板的中的描述。