codecamp
Fecshop 配置结构

Fecshop 配置结构

fecshop 配置结构是层级覆盖的方式,通过yii2的 yii\helpers\ArrayHelper::merge()函数
将所有的配置进行合并,最终成为一个大数组。配置结构通过层级覆盖的方式可以很方便的对fecshop的功能进行重写

配置文件以及优先级

1.fecshop合并的配置文件:

fecshop配置是根据优先级,优先级高的配置可以覆盖优先级低的配置, 优先级由低到高的排列如下(其实就是index.php中的代码):

$config = yii\helpers\ArrayHelper::merge(
    require(__DIR__ . '/../../common/config/main.php'),
    require(__DIR__ . '/../../common/config/main-local.php'),
    require(__DIR__ . '/../config/main.php'),
    require(__DIR__ . '/../config/main-local.php'),
    # fecshop services config
    require(__DIR__ . '/../../vendor/fancyecommerce/fecshop/config/fecshop.php'),
    # fecshop module config
    require(__DIR__ . '/../../vendor/fancyecommerce/fecshop/app/appfront/config/appfront.php'),

    
    # thrid part confing

    
    # common modules and services.
    require(__DIR__ . '/../../common/config/fecshop_local.php'),

     
    # appadmin local modules and services.
    require(__DIR__ . '/../config/fecshop_local.php')

    
);

1到4,是Yii2框架的配置文件结构:

1.@common/config/main.php # Yii2 公用配置,一般是Yii2的一些组件的公用配置。

2.@common/config/main-local.php # Yii2 本地公用配置,一般是Yii2的一些数据库组件的配置

3.@app/config/main.php # Yii2 本app内的配置

4.@app/config/main-local.php # Yii2 本app内的本地配置

5和6部分,是fecshop的配置文件结构:

5.@vendor/fancyecommerce/fecshop/config/fecshop.php # Fecshop的公用配置,一般是组件和服务的配置。

6.@vendor/fancyecommerce/fecshop/app/appfront/config/appfront.php # Fecshop appfront这个入口的独有配置,里面包含模块和一些组件的配置。

第7部分为第三方开发的扩展的配置引入部分,您使用的第三方插件的配置,可以在这里引入进来。

7.第三方配置文件地址。

8和9部分,是二次开发者的配置文件部分:

8.@common/config/fecshop_local.php # 二次开发者的各个入口的公用配置

9.@app/config/fecshop_local.php # 二次开发者的当前入口的独有配置

上面8个配置文件的内容,通过yii\helpers\ArrayHelper::merge()函数合并,最后 形成一个数组,在合并的过程中,1的优先级最低,8个优先级最高,优先级高的配置 项可以覆盖优先级低的配置项。

覆盖顺序:

1.fecshop(5-6)可以覆盖前面Yii2的配置项(1-4)
2.第三方扩展(7),可以覆盖fecshop的配置项(1-6)
3.二次开发者(8-9)可以覆盖上面所有的配置(1-7)

2.对于运费的配置,是通过csv的方式存储公式,路径为

@common/config/shipping/fast_shipping.csv

3.yii class map重写机制

$yiiClassMap = require(__DIR__ . '/../config/YiiClassMap.php');
if(is_array($yiiClassMap) && !empty($yiiClassMap)){
    foreach($yiiClassMap as $namespace => $filePath){
        Yii::$classMap[$namespace] = $filePath;
    }
}

通过classMap的配置,可以重写任意一个class文件,譬如

<?php
return [
    'fecshop\app\appfront\helper\test\My' => '@appfront/helper/My.php',   
];

具体使用方法参看文章:通过配置的方式重写某个Yii2 文件 或第三方扩展文件

优先级部分配置细化 - yii\helpers\ArrayHelper::merge()部分

上面的9个配置文件,有的配置文件还包含其他的配置文件,下面逐一列举

1.@vendor/fancyecommerce/fecshop/config/fecshop.php

该配置文件包含:

1.1@vendor/fancyecommerce/fecshop/config/services/*.php ,这个文件夹下面所有的php配置文件,这里面是各个Fecshop Services(服务)的配置

1.2@vendor/fancyecommerce/fecshop/config/components/*.php ,这个文件夹下面的所有的php文件,这里面是各个Fecshop Component(组件)的配置

2.@vendor/fancyecommerce/fecshop/app/appfront/config/appfront.php

该配置文件包含:

2.1@vendor/fancyecommerce/fecshop/app/appfront/config/params.php 这里面是一些参数的默认配置。

2.2@vendor/fancyecommerce/fecshop/app/appfront/config/modules/*.php 这个文件夹下面所有的php配置文件,这里面是各个模块对应的配置

3.@common/config/fecshop_local.php

该配置文件包含:

3.1@common/config/fecshop_local_modules/*.php 这个文件夹下面所有的php配置文件,这里面是二次开发的公用部分,添加或重写的 模块方面的配置

3.2@common/config/fecshop_local_services/*.php 这个文件夹下面所有的php配置文件,这里面是二次开发的公用部分,添加或重写的 服务方面的配置

4.@app/config/fecshop_local.php

该配置文件包含:

4.1@app/config/fecshop_local_modules/*.php 这个文件夹下面所有的php配置文件,这里面是二次开发的公用部分,添加或重写的 模块方面的配置

4.2@app/config/fecshop_local_services/*.php 这个文件夹下面所有的php配置文件,这里面是二次开发的公用部分,添加或重写的 服务方面的配置

一开始说的9个配置文件,以及对应的这些细分的配置文件,共同组合起来合并,形成 fecshop的最终配置。

通过配置项的覆盖,我们就可以重写各个组件,服务等功能,二次开发自己的功能。

配置加速

配置文件的合并是在index.php文件中, 为了加速,您可以把合并后的数组放到缓存中,然后直接读取出来,节省数据合并带来的开销。 如果您更新了配置,您需要刷新一下缓存让更新的配置生效。

Fecshop 介绍
Fecshop 货币
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

Fecshop 简介

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }