ciniran

ciniran

这家伙有点懒,还没写个性签名!

  • 财富值340
  • 威望值30
  • 总积分740

个人信息

  • 2018-08-29 已签到
    连续签到1天,获得了5个金钱
  • 2018-08-14 已签到
    连续签到1天,获得了5个金钱
  • 没有看到有编辑的地方,就在评论里发了一下说明文档了

  • 系统字典模块

    扩展介绍

    我们在很多系统中,往往需要维护很多字典项目,一般的字典项目包含有一个大类名称、字典项目名称、字典值、等字段,这些内容往往大同小异,
    如在车辆管理中,我们可能需要维护:车辆类型、车辆品牌、车辆用途、路途类别、用车评价、车辆状态等等信息,这些是很简单的数据,
    用来给业务功能使用的,是一个下拉列表形的数据,如果我们为每个这样的简单类型都创建一个表的话,那么有以下坏处:

    1) 如果业务模块很多,就会产生很多这样的表,看起来不雅,维护也不方便,增加工作量。

    2) 会产生很多页面代码(你需要维护界面内容展示和录入),也是看起来不雅,不方便维护,增加工作量。

    3) 代码中调用处理也不好,记不住哪个是具体的字典信息了,太多。

    以上总结一句话,就是做重复工作,就算有一键生成代码的工具,也是不好的。

    如果采用一个公用的字典管理模块能够解决以上问题,那么整个世界就清净了,一句话,简单。
    本扩展能为你解决以上问题。

    插件特点

    1.适合企业级开发,规范多人合作开发,方便统一定义

    2.通过使用缓存,提高运行效率

    3.调用方便、简单,容易使用

    4.本扩展只依赖于 YII2,无其它第三方依赖,简洁、干净

    5.本扩展支持多语言配置

    6.本扩展已完成字典管理界面,开箱即用,无需再次开发。

    7.可按 YII 组件调用,也可以静态调用

    8.组件调用为单例方式,提高效率

    9.新加入了条目排序功能

    ————————————————————————————————————————————————

    安装方法:

    1.推荐通过使用composer.安装此扩展,一切将自动完成

    你可以通过运行以下代码

        php composer.phar require ciniran/yii2-dic "*"
    

    手动安装和配置方法:

    1.下载模块源码并解压缩到你期望的目录,如:

        vendor/ciniran/yii2-dic
    

    2.在 config/main.php 添加如下配置,启用字典管理模块,请注意一定要加入别名,不然可能访问不到

        'modules' => [
            'dic' => [
                'class' => 'ciniran\dic\Module',
            ],
        ],
        'aliases' => [
            '@ciniran/dic' => '@vendor/ciniran/yii2-dic'
        ],
    

    3.在公共配置文件中启用系统组件,按如下配置,您就可以使用 Yii::$app->dic->getKey('base_status');取值了

       'components' => [
              'dic'=>[
                  'class'=>'\ciniran\dic\components\DicTools',
                     ],
              ]
    

    4.程序会自动检测并创建一个 system_dic 的数据表。

    5.本程序支持多语言配置,

    多语言配置文件位@vendor/ciniran/yii2-dic/message/ 目录之下 
    

    ————————————————————————————————————————————————————————

    使用方法:

    1. 在你的后台访问 http://yourdomain/dic,可以进行数据库的字典配置

    2. 视图文件中使用示例:

    
    <?php echo GridView::widget([
        'dataProvider' => $dataProvider,
        'filterModel' => $searchModel,
        'columns' => [
            'id',
            'value',
            'name',
            [
                'attribute' => 'status',
                'filter'=>Yii::$app->dic->getKey(base_status),
                'value' => function ($model) {
                    return Yii::$app->dic->getText('do_status', $model->status);
                }
            ],
                     ]
      ?>
    

    具体可调用工具类如下:

    1.强制删除缓存,无返回值

          SysDic::cleanSystemDic();
    

    2.取得所有字典的数组,

         $array = Yii::$app->dic->getAllKeys(); //通过缓存取得
         
         $array = Yii::$app->dic->getAllKeys(false); //不通过缓存取得
    
    

    3.通过设定的名称取得字典数组

          $array =Yii::$app->dic->getKey('base_status'); //通过缓存取得
          
          $array =Yii::$app->dic->getKey('base_status',true); //获得已被禁用的项目
     
    
    

    4.通过设定的字典值取得显示值

            $string = Yii::$app->dic->getText('base_status','1');
    
    

    5.通过显示值取得字典值

            $value = Yii::$app->dic->getCode('base_status','是');
    
    

    6.正式版本加入了静态调用的方式,具体如下

           $value = SysDic::getCode('base_status', '是');
    
    

    如果本扩展有帮助到你,或者您觉得好用,请不要忘记为我点个star,非常感谢!




  • 最近对这个工具升级了一下,加入了排序,加入按yii组件调用的方式,优化缓存及单例模式

  • 2018-04-26 已签到
    连续签到2天,获得了10个金钱
  • 2018-04-25 已签到
    连续签到1天,获得了5个金钱
  • 2018-04-23 已签到
    连续签到1天,获得了5个金钱
  • 2018-04-13 已签到
    连续签到1天,获得了5个金钱
  • 2018-03-30 已签到
    连续签到1天,获得了5个金钱
主管 等级规则
740/1000
资料完整度
40/100
用户活跃度
0/100

Ta的关注

0

Ta的粉丝

2

Ta的访客

8