2.0.8 • Published 3 years ago

epmp-scripts v2.0.8

Weekly downloads
7
License
MIT
Repository
github
Last release
3 years ago

epmp-scripts

npm version NPM downloads


NPM


介绍

集成了最新的技术栈包括babel7,autoprefixer,less,postcss,webpack4、高度封装、简化配置、无多余依赖、具有服务启动、开发调试、代理访问、数据模拟、构建资源、自动刷新功能。快速开发EPMP微服务工程底层配套工具支撑

安装

工具可以依赖EPMP项目工程通过scripts运行

使用

  1. 通过npm scripts启动
# 开发启动
$ npm start

# 开发构建
$ npm run build

内置已经集成epmp-scripts的启动

启动方式对比优劣

全局启动和项目内脚本启动区别:

启动方式优点缺点
全局启动无需根据项目一次次安装重复依赖npm包节省磁盘空间速度不受项目内工具版本控制,会导致每个开发者环境不统一,出现未知版本错误等
脚本启动无需管理全局环境变量、不污染全局变量、随时根据项目内版本更新、可控每一次版本多次项目使用需要反复安装、占用磁盘空间大

项目配置文件说明

EPMP微服务前端工程核心配置文件只有一个epmp.config.js下面对配置文件说明:

module.exports = () => {
    return {
        // 启动所有模块,默认这个配置,速度慢的时候使用另外的配置
        // bootList: true,

        // 启动这两个模块,不启动调试,关闭构建
        bootList: [
            "demo-app-org",
            //"demo-app-staff"
        ],
        // 代理的配置
        proxy: [
            {
                enable: true,
                headers: {
                    // 与下方url一致
                    "Referer": "http://iuap-meger-demo.test.app.yyuap.com"
                },
                //要代理访问的对方路由
                router: [
                    '/iuap'
                ],
                // pathRewrite: {
                //     '^/api/old-path': '/api/new-path', // rewrite path
                //     '^/api/remove/path': '/path' // remove base path
                // },
                url: 'http://iuap-meger-demo.test.app.yyuap.com'
            }
        ],
        // 静态托管服务
        static: 'src/epmp-common/src/static',
        // 是否展开静态引用资源
        resExtra: true,
        // 构建资源是否产出SourceMap
        openSourceMap: true,
        // 全局环境变量
        globalEnv: {
            GROBAL_HTTP_CTX: JSON.stringify("/iuap_demo"),
        },
        // 别名配置
        alias: {
            //'epmp-apps': path.resolve(__dirname, 'src/epmp-apps/')
        },
        // 构建排除指定包
        externals: {
            //'tinper-bee': 'TinperBee'
        },
        // 调试服务需要运行的插件
        devPlugins: [],
        // 构建服务需要运行的插件
        buildPlugins: []
    }
}

功能配置节点说明

配置项说明默认值可选值备注
bootList启动、构建入口配置,true表示所有模块全部启用,数组参数按需模块使用truetrue,['app-name','app-demo']一般默认开启所有模块的调试和构建,低配置机器或者只需要开发一块模块的话可以选择性的去配置单独启动
proxy开发调试阶段的代理服务配置[]enable:true 是否有效代理,false表示关闭. headers:{} 设置代理请求的消息头. router:['/iuap','wbalone']. url:'proxy.example.com'. 本地请求代理对方服务器地址. pathRewrite:{}URL重写服务. opts:{} 如内置配置无法满足需求,需要单独设置原生配置 http-proxy-middleware.数组节点可以配置多条代理服务,通过enable来控制启用哪个,针对一些服务器校验头信息例如:Referer等就需要设置,其他常规的设置工具已经内置,代理路由router表示设置的几个路由访问后会代理到对方服务器上,url就是对方服务器地址
globalEnv程序内公共变量null同webpack4 { key : value }接收K、V格式如:{GROBAL_HTTP_CTX: JSON.stringify("/iuap_demo")}
alias别名null同webpack4 {key : value}接收K、V格式如:{'epmp-apps': path.resolve(__dirname, 'src/epmp-apps/')}
externals排除指定的包用外部变量代理提升打包性能null同webpack4 { key : value }接收K、V格式如:{'tinper-bee': 'TinperBee'}
loader内置加载器无法处理需要单独去设置处理[]同webpack4 loader
devPlugins开发环境加载的插件[]同webpack4 plugin开发阶段使用的插件
buildPlugins生产环境加载的插件[]同webpack4 plugin生产阶段使用的插件
openSourceMap构建资源生产环境的时候产出sourceMaptruetrue,false-
csscss loader的optionsundefined-具体参考https://www.npmjs.com/package/css-loader
lessless loader的optionsundefined-具体参考https://www.npmjs.com/package/less-loader
resExtra是否展开静态引用资源,用于打包处理字体、图片等资源产出,或者不使用展开资源会打包到css方便管理truetrue,false-
static静态托管服务,不按需打包undefined-脚手架内的任意文件夹即可,如:static : 'epmp-common/src/static'
babelPresetsbabel使用的 presetsundefined-如:require.resolve('@babel/preset-react')
babelPluginsbabel的插件undefined如:require.resolve("babel-plugin-import-bee")
scanRoot自定义文件夹作为扫描微应用入口,原则上是按照./自定义目录/*/src/app.js扫描undefined-
distRoot输出自定义文件夹undefined-
host自定义IP、域名启动undefined支持IPV4、IPV6、域名
postcssPluginsPostCss Pluginundefined-

自动开启浏览器

通过配置npm启动命令:

  "scripts": {
    "start": "epmp-scripts start --homepage=demo-app-org",
    "build": "epmp-scripts build"
  }

版本

  • 0.1.1 初始版
2.0.3

3 years ago

2.0.2

3 years ago

2.0.5

3 years ago

2.0.4

3 years ago

2.0.7

3 years ago

2.0.6

3 years ago

2.0.8

3 years ago

2.0.1

3 years ago

2.0.0

3 years ago

1.1.7

3 years ago

1.1.6

4 years ago

1.1.5

4 years ago

1.1.4

4 years ago

1.1.3

4 years ago

1.1.2

4 years ago

1.1.1

4 years ago

1.1.0

4 years ago

1.0.10

4 years ago

1.0.9

4 years ago

1.0.8

4 years ago

1.0.7

4 years ago

1.0.6

4 years ago

1.0.5

4 years ago

1.0.2

4 years ago

1.0.4

4 years ago

1.0.3

4 years ago

1.0.1

4 years ago

1.0.0

4 years ago

0.2.0

4 years ago

0.1.66

4 years ago

0.1.65

4 years ago

0.1.64

4 years ago

0.1.63

4 years ago

0.1.61

4 years ago

0.1.62

4 years ago

0.1.60

4 years ago

0.1.57

4 years ago

0.1.58

4 years ago

0.1.56

4 years ago

0.1.55

4 years ago

0.1.54

4 years ago

0.1.52

4 years ago

0.1.53

4 years ago

0.1.51

4 years ago

0.1.7

4 years ago

0.1.6

4 years ago

0.1.5

4 years ago

0.1.4

4 years ago

0.1.3

4 years ago

0.1.2

4 years ago

0.1.1

4 years ago

0.1.0

4 years ago