首頁  >  文章  >  web前端  >  用CDN的react webpack打包文件

用CDN的react webpack打包文件

php中世界最好的语言
php中世界最好的语言原創
2018-03-17 15:24:132946瀏覽

這次帶給大家用CDN的react webpack打包文件,用CDN的react webpack打包文件的注意事項有哪些,下面就是實戰案例,一起來看一下。

此文不介紹webpack基本配置,若對基本配置有疑問請查閱官方文件。

1、設定webpack.config.js

#將output.publicPath改成上傳到的cdn位址, 例(對應上面上傳配置):

publicPath: "https://your_base_cdn_url" + process.env.NODE_ENV + "/cdn/"

打包

NODE_ENV=production node_modules/webpack/bin/webpack.js -p

這樣打包後的檔案例如有

index.html
12345678.src.js
12345678.src.css
...

此時,打包後產生的index.html檔案中已經引入了cdn檔案。

<html lang="en">
<head>
 <title>title</title>
 <link href="https://your_base_cdn_url/production/cdn/12345678.src.css" rel="external nofollow" rel="stylesheet">
</head>
<body id="body">
 <p id="root"></p>
<script src="https://your_base_cdn_url/production/cdn/12345678.src.js"></script></body>
</html>

2、上傳檔案至CDN

#在部署腳本中寫一段上傳cdn的腳本, 例:

echo "start uploading to upyun"
HOST=v0.ftp.upyun.com
USER=uploader/your-username
PASS=your-password
cd build
files=$(ls | grep -v 'index.html' | xargs)
ftp -inv $HOST <<EOF
user $USER $PASS
mkdir /$node_env/cdn
cd /$node_env/cdn
mput $files
bye
EOF
cd ..
echo "finish uploading to upyun"

將首頁檔案上傳至伺服器,使用nginx代理

server {
 listen 80;
 server_name your_server_name;
 access_log /var/log/nginx/your_project.log;
 root /var/www/your_project/production/current;
 location / {
 try_files $uri /index.html =404;
 add_header Pragma no-cache;
 expires -5y;
 }
 location ~ \.(js|css)$ {
 expires 360000;
 add_header Cache-Control "max-age=360000;";
 }
}

造訪http://your_server_name即可存取使用CDN加速後網頁。

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

JS實作預設頭像填號

babel的使用詳解

以上是用CDN的react webpack打包文件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn