1.4.7 • Published 15 days ago

joyer-cli v1.4.7

Weekly downloads
50
License
MIT
Repository
-
Last release
15 days ago

京东金融构建工具joyer-cli

遇到问题怎么办

  • 这里搜索问题、提交问题

Node版本

  • 统一使用最新的LTS版本,目前为v8.12.0(LTS),推荐安装方式nvm

  • 统一使用npm作为包管理工具,不使用yarn

    • 原因:npm从5.x版本以后已经加入yarn的大部分特性,包括package-lock.json、默认--save、cache重写带来的安装速度提升(不输yarn)等,详见
    • Node v8.x内置了npm v6.x,交叉使用npm和yarn会产生功能类似的重复文件及一些未知风险,使用比例

使用文档

安装joyer-cli

  • npm install joyer-cli -g

  • 绑定host(为了能上传预发环境):

    • 172.23.190.105 check.jr.jd.com
  • 版本1.0.13之后不再需要此操作

    • 设置环境变量JOYER_GIT_TOKEN=[Private token](为了能从git.jd.com获取模板和组件):
    • 获取Private token, 登录git.jd.com -> 右上角头像-Settings -> 左侧Account -> Private token
    • mac设置:
      • Terminal用户:打开Terminal,输入echo 'export JOYER_GIT_TOKEN=[Private token]' >> ~/.bash_profile && source ~/.bash_profile
      • zsh用户:打开zsh,输入echo 'export JOYER_GIT_TOKEN=[Private token]' >> ~/.zshrc && source ~/.zshrc
    • win设置,打开cmd,输入setx JOYER_GIT_TOKEN [Private token] && set JOYER_GIT_TOKEN [Private token]
    • 重要:把[Private token]整个替换,包括两边的中括号

joyer init 创建新项目

  • joyer init -h 输出帮助提示

  • joyer init -l 输出可用模板列表

  • joyer init <name> 使用指定模板创建项目,是joyer init -t <name>的缩写

  • joyer init 不传递参数,创建项目的过程中会提示选择模板

  • 以上<name> 参数均可使用模板索引传入, 例如:

    joyer init -l输出:

    0.zepto - based on zepto, applicable for simple single page
    1.vue   - based on vue, applicable for complex project
    2.react - based on react, applicable for complex project, too

    我们可以使用joyer init 1或者joyer init vue来指定使用vue模板创建项目

  • 若要终止创建项目,ctrl+c结束进程即可

joyer install 安装模板组件joyer-components

  • joyer install -l 列出所有当前模板可用组件

  • joyer install componentNameA componentNameB 指定组件名并安装

  • joyer install 安装所有可用组件(会覆盖本地已有的组件)

joyer mock 在当前目录启动一个mock服务

  • 当前目录需要有mock.js文件,详细文档见mock wiki

  • 启动命令:

    joyer mock //默认端口8001

    joyer mock -p 8090 //指定端口8090

joyer serve 静态部署

  • joyer serve -h 输出有关serve子命令的帮助提示

  • joyer serve -v 查看该joyer-serve版本号

  • 我们可以通过在serve后面加入path、port来更加精准的操作它

    joyer serve 默认3000端口的当前子目录

    joyer serve <path> 部署指定目录

    joyer serve <path> -p <port> 部署指定port的指定目录

  • 若要终止serve的运行,ctrl+c结束进程即可

joyer-cli内置构建环境文档

重要依赖及选择原因

  • webpack@4.20.2

    • 目前为最新的稳定版本,相比3.x编译速度提升了近2倍,更好的代码分离机制,更多的模块类型支持,详见
    • 使用其node api模式而非cli模式,目的在于有利于开发环境同时并存多个webpack版本,缺点是每个文件目录会比较大
    • 疑问点,目前大部分项目应该是在3.x版本下构建,迁移成本?
  • webpack-dev-server@3.1.9

    • 目前最新的稳定版本,适配webpack@4.x,v3.1.2之前的版本存在proxy的bug

  • @babel/preset-env@7.1.0

    • 完美解决了babel-polifyll的问题,无需全量打包
  • @babel/core@7.1.2

    • 适配@babel/preset-env@7.1.0

问题记录

  • joyer install <template> 原计划到source.jd.com上面专门开一个repo用来存放和维护今后要用到的模板,但由于访问需要登录,故放弃

    • 替代方案:在joyer-cli项目中内置template目录,用于存放模板。缺点:可拓展性差,需要发版才能更新模板,耦合性较强。
    • 后续考虑:可否把模板放到类似github的开源平台进行维护?
    • 结论:在git.jd.com平台建立group作为模板仓库(joyer-template)和组件仓库(vue-components/zepto-components),通过gitlab api来抽取模板和组件
    • 缺点:需要把自己的private token绑定到环境变量JOYER_GIT_TOKEN,这已经是目前能想到的最小成本的方案了,后续待讨论...
    • 更新:绑定了个人的具有时效的access_token,这样就无需使用者再绑定了 @2018-12-19
  • 考虑实现类似joyer upgrade来更新组件库?

    • 开始考虑实现类似joyer-template的方式进行组件安装及更新,但维护成本较高且可能会有版本依赖问题
    • 结论:和军哥讨论后决定使用模板集成组件的方式来维护组件库,把组件库内置到模版中指定的目录,通过joyer install命令来重新安装组件库
  • 考虑替代通过检测process.env的方式来区分域名及环境,原因reading-environment-variables-is-slow-operation

    • 结论:joyer模板中joyer-config新增字段env,然后脚手架通过DefinePlugin设置编译时变量
  • 抽离公共css的过程中发现了问题:optimization.splitChunks.cacheGroups.{cacheGroups}.enforce: true会产生一个空的js文件,目前还没有官方解决方案

  • 然后抽离css过程中发现新问题,在scss中使用@import引入的common.scss不会被抽离

    • 解决方案:编译完成后,将所有文件中引入的common.scss中的内容匹配并移除
  • html-webpack-plugin和html-loader同时使用,会使html-webpack-plugin注入html变量失效

    • 实现基于joyer-config的变量系统,在配置文件中添加env字段用来放置编译相关的变量
    • 困难:webpack.DefinePlugin不能在html文件中定义变量
    • 解决方案:实现webpack plugin用于替换html中指定字符
  • open-browser-webpack-plugin在windows子系统linux(Bash on Windows)中存在问题,不能打开浏览器

    • 使用兼容性更好的opn代替
  • 单页面应用使用history模式时,想利用HtmlWebpackPlugin输出多个index.html文件到各个路由目录,发现它不支持相对路径,导致路由目录下的index.html文件资源引用出错

1.4.8-rc.64

15 days ago

1.4.8-rc.63

15 days ago

1.4.8-rc.62

19 days ago

1.4.8-rc.61

21 days ago

1.4.8-rc.60

1 month ago

1.4.8-rc.59

3 months ago

1.4.8-rc.58

3 months ago

1.4.8-rc.57

4 months ago

1.4.8-rc.56

4 months ago

1.4.8-rc.55

4 months ago

1.4.8-rc.54

4 months ago

1.4.8-rc.53

5 months ago

1.4.8-rc.52

5 months ago

1.4.8-rc.51

5 months ago

1.4.8-rc.49

5 months ago

1.4.8-rc.48

6 months ago

1.4.8-rc.47

6 months ago

1.4.8-rc.46

6 months ago

1.4.8-rc.45

6 months ago

1.4.8-rc.44

6 months ago

1.4.8-rc.50

5 months ago

1.4.8-rc.42

6 months ago

1.4.8-rc.43

6 months ago

1.4.8-rc.39

8 months ago

1.4.8-rc.41

8 months ago

1.4.8-rc.40

8 months ago

1.4.8-rc.31

11 months ago

1.4.8-rc.38

9 months ago

1.4.8-rc.37

9 months ago

1.4.8-rc.36

9 months ago

1.4.8-rc.35

10 months ago

1.4.8-rc.34

10 months ago

1.4.8-rc.33

10 months ago

1.4.8-rc.32

10 months ago

1.4.8-rc.29

1 year ago

1.4.8-rc.28

1 year ago

1.4.8-rc.27

1 year ago

1.4.8-rc.30

12 months ago

1.4.8-rc.26

1 year ago

1.4.8-rc.25

1 year ago

1.4.8-rc.24

1 year ago

1.4.8-rc.23

1 year ago

1.4.8-rc.22

1 year ago

1.4.8-rc.20

1 year ago

1.4.8-rc.9

1 year ago

1.4.8-rc.3

1 year ago

1.4.8-rc.4

1 year ago

1.4.8-rc.1

1 year ago

1.4.8-rc.2

1 year ago

1.4.8-rc.7

1 year ago

1.4.8-rc.8

1 year ago

1.4.8-rc.5

1 year ago

1.4.8-rc.6

1 year ago

1.4.8-rc.21

1 year ago

1.4.7-rc.1

1 year ago

1.4.7-rc.0

2 years ago

1.4.8-rc.0

1 year ago

1.4.8-rc.19

1 year ago

1.4.8-rc.18

1 year ago

1.4.7

1 year ago

1.4.8-rc.17

1 year ago

1.4.8-rc.16

1 year ago

1.4.8-rc.15

1 year ago

1.4.8-rc.14

1 year ago

1.4.8-rc.13

1 year ago

1.4.8-rc.12

1 year ago

1.4.8-rc.11

1 year ago

1.4.8-rc.10

1 year ago

1.4.6

2 years ago

1.4.5

2 years ago

1.4.4

2 years ago

1.4.3

2 years ago

1.4.2-rc.2

2 years ago

1.4.2-rc.1

2 years ago

1.4.2-rc.0

2 years ago

1.4.2

2 years ago

1.4.1

2 years ago

1.4.0

2 years ago

1.4.1-rc.0

2 years ago

1.4.1-rc.1

2 years ago

1.4.0-rc.0

2 years ago

1.4.0-rc.1

2 years ago

1.3.6

2 years ago

1.3.5

2 years ago

1.3.4-rc.10

2 years ago

1.3.4

2 years ago

1.3.4-rc.9

2 years ago

1.3.4-rc.8

2 years ago

1.3.4-rc.7

2 years ago

1.3.4-rc.6

2 years ago

1.3.4-rc.5

2 years ago

1.3.4-rc.4

2 years ago

1.3.4-rc.3

2 years ago

1.3.4-rc.2

2 years ago

1.3.4-rc.1

2 years ago

1.3.4-rc.0

2 years ago

1.3.3

3 years ago

1.3.3-rc.3

3 years ago

1.3.3-rc.4

3 years ago

1.3.3-rc.2

3 years ago

1.3.3-rc.0

3 years ago

1.3.3-rc.1

3 years ago

1.3.2

3 years ago

1.3.1

3 years ago

1.3.0-rc.20

3 years ago

1.3.0

3 years ago

1.3.0-rc.19

3 years ago

1.3.0-rc.16

3 years ago

1.3.0-rc.18

3 years ago

1.3.0-rc.17

3 years ago

1.3.0-rc.15

3 years ago

1.3.0-rc.14

3 years ago

1.3.0-rc.12

3 years ago

1.3.0-rc.13

3 years ago

1.3.0-rc.11

3 years ago

1.3.0-rc.8

3 years ago

1.3.0-rc.9

3 years ago

1.3.0-rc.7

3 years ago

1.3.0-rc.10

3 years ago

1.3.0-rc.6

3 years ago

1.3.0-rc.3

3 years ago

1.3.0-rc.4

3 years ago

1.3.0-rc.5

3 years ago

1.3.0-rc.2

3 years ago

1.3.0-rc.1

3 years ago

1.2.3

4 years ago

1.2.1

4 years ago

1.2.0

4 years ago

1.2.0-rc.3

4 years ago

1.2.0-rc.2

4 years ago

1.2.0-rc.1

4 years ago

1.2.0-rc.0

4 years ago

1.1.10

4 years ago

1.1.10-rc.0

4 years ago

1.1.9

5 years ago

1.1.8

5 years ago

1.1.8-rc.0

5 years ago

1.1.7

5 years ago

1.1.7-rc.0

5 years ago

1.1.6

5 years ago

1.1.6-rc.3

5 years ago

1.1.6-rc.2

5 years ago

1.1.6-rc.1

5 years ago

1.1.6-rc.0

5 years ago

1.1.5

5 years ago

1.1.5-rc.1

5 years ago

1.1.5-rc.0

5 years ago

1.1.4

5 years ago

1.1.3

5 years ago

1.1.2

5 years ago

1.1.1

5 years ago

1.1.0

5 years ago

1.0.23

5 years ago

1.0.22

5 years ago

1.0.21

5 years ago

1.0.20

5 years ago

1.0.19

5 years ago

1.0.18

5 years ago

1.0.17

5 years ago

1.0.16

5 years ago

1.0.15

5 years ago

1.0.14

5 years ago

1.0.13

5 years ago

1.0.12

5 years ago

1.0.11

5 years ago

1.0.10

5 years ago

1.0.9

5 years ago

1.0.8

5 years ago

1.0.7

5 years ago

1.0.6

5 years ago

1.0.5

5 years ago

1.0.4

5 years ago

1.0.3

5 years ago

1.0.2

5 years ago

1.0.1

5 years ago

1.0.0

6 years ago