ant design pro (八)构建和发布

摘要:
可以参考create-react-app的部署文档{"publicPath":"https://cdn.com/your_app"}AntDesignPro1.0版本后我们.webpackrc里使用了"disableDynamicImport":true默认关掉了动态加载,回退为单文件index.js和index.css的构建方式。express的例子app.use;app.get;egg的例子//controllerexports.index=function*(){yieldthis.render;};//routerapp.get;2.2.3、在AntDesignPro中使用前端路由路由包含的信息在router.js中,不过关于history的配置是在index.js入口文件中,传入配置信息给dva构造器即可。由于使用了react-router@4,所以引入browserHistory与原本dva的方式相比有所改变。

一、概述

原文地址:https://pro.ant.design/docs/deploy-cn

二、详细

2.1、构建

当项目开发完毕,只需要运行一行命令就可以打包你的应用:

npm run build

由于 Ant Design Pro 底层使用的roadhog工具,已经将复杂的流程封装完毕,对于大部分场景,构建打包文件只需要一个命令roadhog build,构建打包成功之后,会在根目录生成dist文件夹,里面就是构建打包好的文件,通常是***.js***.cssindex.html等静态文件。

不过你如果需要自定义构建,比如指定dist目录等,则需要通过.webpackrc进行配置,详情参看:roadhog 配置

2.1.1、环境变量

当你需要区别开发和部署以及测试环境的时候,可以通过在.webpackrc中设置env环境变量来实现。

"env": {
  // 开发环境
  "development": {
    "extraBabelPlugins": [
      "dva-hmr",
    ]
  },
  // build 时的生产环境
  "production": {
    "extraBabelPlugins": [
      "transform-runtime",
      "transform-decorators-legacy",
      ["import", { "libraryName": "antd", "style": true }]
    ]
  }
},

2.1.2、分析构建文件体积

如果你的构建文件很大,你可以通过analyze命令构建并分析依赖模块的体积分布,从而优化你的代码。

npm run analyze

ant design pro (八)构建和发布第1张

然后打开dist/stats.html查看体积分布数据。

ant design pro (八)构建和发布第2张

2.2、发布

对于发布来讲,只需要将最终生成的静态文件,也就是通常情况下dist文件夹的静态文件发布到你的 cdn 或者静态服务器即可,需要注意的是其中的index.html通常会是你后台服务的入口页面,在确定了 js 和 css 的静态之后可能需要改变页面的引入路径。

2.2.1、代码分割和动态加载

0.3.0 版本之后,我们支持了代码分割和动态加载,只有进入对应路由后才会加载相应的代码,避免首屏加载过多不必要的 JS 文件,提高大规模前端应用研发的扩展性。

├── 0.async.js
├── 1.async.js
├── 10.async.js
├── 11.async.js
├── 12.async.js
├── 13.async.js
├── 14.async.js
...

注意:如果开启了hash,会变成0.2df975b2.async.js的形式,修改代码后 hash 会变化,可以避免前端缓存问题。

这种方式对于部署有一定的要求,你可以将 dist 整体部署到你的后端应用的静态资源目录下(通常为 static 或者 public),这样默认的静态资源引用路径直接指向应用的根目录//your.application.domain/***.js//your.application.domain/***.css

如果你的静态资源域名和应用域名不同(例如独立的 cdn 地址),你需要在.webpackrc文件里用publicPath对生产环境的静态路径进行配置。可以参考create-react-app 的部署文档

{
  "publicPath": "https://cdn.com/your_app"
}

Ant Design Pro 1.0 版本后我们.webpackrc里使用了"disableDynamicImport": true默认关掉了动态加载(roadhog@2.x 支持),回退为单文件 index.js 和 index.css 的构建方式。如果需要动态加载删掉这个配置即可。

2.2.2、前端路由与服务端的结合

Ant Design Pro 中,前端路由使用的是React Router,所以你可以选择两种路由方式:browserHistoryhashHistory

  hashHistory使用如https://cdn.com/#/users/123这样的 URL,取井号后面的字符作为路径。browserHistory则直接使用https://cdn.com/users/123这样的 URL。使用hashHistory时浏览器访问到的始终都是根目录下index.html。使用browserHistory则需要服务器做好处理 URL 的准备,处理应用启动最初的/这样的请求应该没问题,但当用户来回跳转并在/users/123刷新时,服务器就会收到来自/users/123的请求,这时你需要配置服务器能处理这个 URL 返回正确的index.html。如果你能控制服务端,我们推荐使用browserHistory

express的例子

app.use(express.static(path.join(__dirname, 'build')));
app.get('/*', function (req, res) {
  res.sendFile(path.join(__dirname, 'build', 'index.html'));
});

egg的例子

// controller
exports.index = function* () {
  yield this.render('App.jsx', {
    context: {
      user: this.session.user,
    },
  });
};
// router
app.get('home', '/*', 'home.index');

2.2.3、在 Ant Design Pro 中使用前端路由

路由包含的信息在router.js中,不过关于history的配置是在index.js入口文件中,传入配置信息给dva构造器即可。

由于使用了react-router@4,所以引入browserHistory与原本dva的方式相比有所改变。

import dva from 'dva';
// 引入 browserHistory
import browserHistory from 'history/createBrowserHistory'
import models from './models';
import './index.less';
// use browserHistory
const app = dva({
  history: browserHistory(),
});
// default hashHistroy
const app = dva();

关于路由更多可以参看React Router。 关于react-router@4更多可以参看All About React Router 4

免责声明:文章转载自《ant design pro (八)构建和发布》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇phpstorm 终端设置c#命名法 【转】下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

顺丰丰桥软件开发工具包 (.NET)

丰桥 - 一站式对接服务平台, 打通客户与顺丰系统之间的信息流, 实现物流供应链一体化. 随着一个电商项目和顺丰合作, 信息流对接就是我们开发的事了. 顺丰通过丰桥提供了一些开放接口, 不过丰桥提供的 SDK 非常简陋, 对 .NET 的支持就更差了. 于是就有了这个项目 sf-express-sdk-net 主要接口集成: 接口 接口方式 描述...

OpenWrt 路由系统上抓包

版权声明:本文为博主原创文章。未经博主同意不得转载。 https://blog.csdn.net/qianguozheng/article/details/32108093 前言: 做路由器开发,难免会遇到抓包的情况,可是抓包须要有Hub或者无线抓包网卡,调试无线问题。且眼下手中没有无线抓包网卡,怎么办?那不能分析无线连接建立的过程,我们就...

Windows:添加、删除和修改静态路由

查看网卡编号 route print 或 netstat -r   添加一条静态路由  route add 192.168.100.0 mask 255.255.255.248 192.168.1.1 metric 3 if 2 添加一条路由记录,所有到192.168.100.0/24网段的数据包,都通过2号(网卡)接口走192.168.1.1的网关...

Newifi OpenWrt 下 EAP-PEAP,EAP-TLS 企业级无线认证及 FreeRadius3

Newifi OpenWrt 下 EAP-PEAP,EAP-TLS 企业级无线认证及 FreeRadius3 转载注明来源: 本文链接 来自osnosn的博客,写于 2019-07-15. 副标题:家用路由器,配置EAP-PEAP,EAP-TLS企业认证的无线接入服务。 家里的WiFi一般是用WPA2认证,密码只有一个,泄漏了,家里所有设备都要换密码。...

dva 路由跳转

1.从props取出并传递history 取 const { history } = this.props 用 <button onClick={ () => history.push('/') }>go back home</button> 2.withRouter, Link withRouter: import {...

开网页自动进入路由器设置界面的解决办法(腾达路由器)

腾达路由器设置完毕后,开网页自动进入路由器设置界面,并且WAN口状态显示连接中 问题1:显示“连接中”怎么办? 原因1:路由器WAN口的上网方式选择错误。 解决方法:进到路由器设置页面,点击“高级设置”-“WAN口设置”选择正确的上网方式. 原因2:宽带的账号和密码输错了或者没有区分大小写 解决方法:输入正确的宽带帐号和密码,注意区分帐号密码大小写。 原...