国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

webpack工程化集成React技術(shù)棧(一)

tianhang / 2720人閱讀

項目開始前,我們先聊一聊關(guān)于項目的一些說明。該項目起始于2017年初,當(dāng)時公司主要技術(shù)棧為gulp+angular,鑒于react的火熱的生態(tài),在公司決定研發(fā)bss管理系統(tǒng)時選用react開發(fā),目的也是為react native打下基礎(chǔ),以解決后期公司大前端技術(shù)棧的逐步成熟。(當(dāng)時沒有選擇vue開發(fā)的主要原因是weex生態(tài)還不夠特別成熟),既然決定換新,項目的構(gòu)建也跟著一起換,從gulp轉(zhuǎn)向火熱的webpack,持續(xù)大半年的更新迭代,我們將構(gòu)建模塊逐步從項目中抽離出來,把構(gòu)建模塊作為npm包多帶帶管理,完成和項目代碼解耦,于是就有了后面我們要說的wci-build構(gòu)建模塊包和wci-cli項目腳手架。

我們要做什么 技術(shù)棧

項目采用前后端分離的形式,后端選用Maven+SpringClould全家桶開發(fā),前端選用webpack+react全家桶開發(fā),前后端全部采用包管理工具完全解決項目依賴管理的難題,版本管理采用git,前后端通過json交互,swgger管理接口文檔,接口全部遵循restful規(guī)范。由于本文面向社區(qū)開放,故本文中不涉及公司業(yè)務(wù)層的代碼,本文全部代碼均為最新編寫,我們以一個旅游管理系統(tǒng)的三個模塊為大家演示項目(登陸登出、用戶模塊、景點模塊)。為了快速開展,本文涉及的后端代碼直接采用Java的SSM框架搭建,源碼也將為大家奉上。朋友們也可以使用mock模擬接口數(shù)據(jù)。后期我們在演示nodejs+espress時將接口代碼全部轉(zhuǎn)為node形式。

準(zhǔn)備

因本文不是講解基礎(chǔ),故大家在敲代碼前,還需要具備一定的前端基礎(chǔ),部分如下

html、css、javascript基礎(chǔ)知識

es6基礎(chǔ)知識

react基礎(chǔ)知識

了解什么是webpack、babel、redux、react-router、nodejs、npm

熟悉螞蟻金服ant design

熟悉less基本使用

解決什么問題

本項目集成了最新的react16、react-router4、redux,同時可以選擇性集成antd|antd mobile,在解決繁瑣的架構(gòu)配置工作外,還解決了以下問題

通用問題

支持開發(fā)效率更高的ES6編寫代碼。

拆分開發(fā)、測試、生產(chǎn)環(huán)境,完成從開發(fā)到上線的所有工作。

開發(fā)環(huán)境包含熱替換,本地IP、端口可配置,接口可配置,微服務(wù)模塊可配置

測試環(huán)境包含代碼壓縮、合并、css抽離、公共組件抽離、代碼添加hash、測試版本后綴

生產(chǎn)環(huán)境包含代碼壓縮、合并、css抽離、公共組件抽離、代碼添加hash、生產(chǎn)版本后綴(和測試代碼完全一樣,只缺少測試版本號)

支持自定義添加webpack loader

其他問題

目前大型項目后端多采用微服務(wù)架構(gòu),API接口在開發(fā)、測試、生產(chǎn)環(huán)境下來回切換,需要頻繁修改代碼。解決方案:通過配置文件的方式統(tǒng)一配置項目模塊接口

項目模塊在分拆開發(fā)的過程中css命名沖突,導(dǎo)致代碼維護性較差。解決方案:構(gòu)建工具預(yù)加載css時自動化添加hash,使css代碼模塊化

不同開發(fā)人員,不同的代碼習(xí)慣造成項目代碼難以維護。解決方案:在代碼編寫、構(gòu)建、版本管理三個方向加入代碼規(guī)范校驗(airbnb規(guī)范)

在同時開發(fā)多個系統(tǒng)的時候,構(gòu)建業(yè)務(wù)模塊在不同的項目都存在,當(dāng)需要修改配置或者優(yōu)化構(gòu)建方案的時候,需要修改多個項目的配置。解決方案:抽離構(gòu)建模塊,采用npm形式依賴。

還有什么問題要解決

雖然經(jīng)過大半年迭代,但我們還需要在實際項目開發(fā)中支持更多的個性化需求

cdn自動化

更加完善的持續(xù)集成

單元測試,包括代碼,交互測試

mock數(shù)據(jù),實現(xiàn)前后端真正0接觸

...

希望

大家在開發(fā)過程中遇到任何問題,希望可以給我們留言,我們會不斷優(yōu)化項目。未來,我們還會加入mobx、rxjs、immutablejs、GraphQL等,也希望在和大家的探討中,持續(xù)進步。

項目準(zhǔn)備

本項目基礎(chǔ)環(huán)境必須依賴nodejs和npm,未安裝的朋友可以去官網(wǎng)自行安裝,安裝教程這里不詳細(xì)說明,安裝完成后使用如下命令,查看是否安裝成功。

node -v
npm -v
初始化項目

本項目我們使用wci-cli腳手架初始化項目

全局安裝wci-cli

npm install -g wci-cli

創(chuàng)建項目

wci-cli 腳手架可以創(chuàng)建三種項目,分別是1.純凈的react項目 2.包含antd的react項目 3.包含antd-mobile的react項目,命令如下

wci new myapp

執(zhí)行命令后,命令行會提示是否需要安裝antd以及選擇antd類型,即可完成項目初始化,如下

項目目錄

myapp
├── app // 項目業(yè)務(wù)代碼
│   ├── assets // 靜態(tài)文件目錄(圖片、字體等)
│   ├── script // js代碼目錄
│   │   ├── actions // redux action目錄
│   │   ├── componets // react 無狀態(tài)組件目錄
│   │   ├── containers // react 業(yè)務(wù)代碼
│   │   ├── reducers // redux reducer目錄
│   │   ├── util // 工具包目錄
│   │   │   ├── theme.js // antd自定義樣式文件
│   │   ├── Home.js // 首頁
│   │   ├── home.less // 首頁樣式
│   ├── styles // 全局樣式目錄
│   ├── index.js // 項目入口文件
│   ├── index.tpl.html // 項目html模版
├── node_modules // 依賴包目錄
├── .babelrc // babel配置文件
├── .eslintrc // eslint代碼校驗配置文件
├── .gitignore
├── package.json
├── README.md
├── wci.json // wci項目配置文件(主要配置一些開發(fā)、測試、生產(chǎn)環(huán)境的信息)
└── webpack.js // webpack自定義配置文件

執(zhí)行如下命令,運行開發(fā)環(huán)境

cd myapp
npm run start

如上圖,我們的項目已經(jīng)跑起來了...

測試、發(fā)布

因我們需要保證測試代碼和生產(chǎn)代碼必須保持一致,所有在實際項目中,我們可以運行如下命令構(gòu)建代碼

npm run test // 測試環(huán)境打包
npm run dist // 生產(chǎn)環(huán)境打包

測試代碼

生產(chǎn)代碼

到這里,我們已經(jīng)完成項目前期開發(fā)的所有準(zhǔn)備工作,接下來,我們一起開始擼代碼吧

項目結(jié)束后,我會為大家奉上兩篇彩蛋,分別是 1. 一步步搭建webpack前端構(gòu)建工具并抽成npm多帶帶模塊 2. 一步步構(gòu)建自己的npm開發(fā)包并且以一個真實例子演示(開發(fā)一個命令行生成文件夾結(jié)構(gòu)的小工具)
還要說一點

正式開始擼代碼前,還要針對項目具體說明,包括項目代碼目錄介紹,前后端分離項目需要注意哪些問題,前后端如何鑒權(quán)等...

都是干什么的
myapp
├── app // 項目業(yè)務(wù)代碼
│   ├── assets // 靜態(tài)文件目錄(圖片、字體等)
│   ├── script // js代碼目錄
│   │   ├── actions // redux action目錄
│   │   ├── componets // react 無狀態(tài)組件目錄
│   │   ├── containers // react 業(yè)務(wù)代碼
│   │   ├── reducers // redux reducer目錄
│   │   ├── util // 工具包目錄
│   │   │   ├── theme.js // antd自定義樣式文件
│   │   ├── Home.js // 首頁
│   │   ├── home.less // 首頁樣式
│   ├── styles // 全局樣式目錄
│   ├── index.js // 項目入口文件
│   ├── index.tpl.html // 項目html模版
├── node_modules // 依賴包目錄
├── .babelrc // babel配置文件
├── .eslintrc // eslint代碼校驗配置文件
├── .gitignore
├── package.json
├── README.md
├── wci.json // wci項目配置文件(主要配置一些開發(fā)、測試、生產(chǎn)環(huán)境的信息)
└── webpack.js // webpack自定義配置文件

以上是代碼的全部目錄,下面我們根據(jù)功能依次介紹:

node_modules、.gitignore、package.json、README.md

node_modules: npm依賴包目錄,開發(fā)者可以不用管,只要知道我們項目里所有的依賴都下載在這個文件夾下
.gitignore:git需要忽略的文件
package.json:npm最主要的文件,里面寫滿了我們依賴包的結(jié)構(gòu)和一些項目信息
README.md:github的說明文件

.babelrc、.eslintrc

.babelrc:babel配置文件,可以配置部分自定義babel插件(例如本項目里antd自定義主題和javascript@語法糖就在這里配置)
.eslintrc:eslint配置文件,可以自定義配置eslint規(guī)則,詳細(xì)規(guī)則可以去官網(wǎng)eslint查看

說明:這兩個模塊本該配置在wci-build構(gòu)建工具里,但考慮到項目的靈活性,所有抽離出來放在項目根目錄

webpack.js

webpack.js:webpack loader個性化的配置文件,可以自定義添加webpack loader

wci.json

wci.json:項目的配置文件,可以自定義配置項目
{
  "index": "app/index.js", // 項目入口文件
  "hostname": "127.0.0.1", // 開發(fā)環(huán)境IP地址(可以配置域名通過本地host轉(zhuǎn)發(fā))
  "name": "wci-antd-app", // 項目名稱(顯示在瀏覽器title里的名字)
  "libs": [ // 項目的公共包,后續(xù)可以自行添加
    "react",
    "react-dom",
    "axios",
    "classnames",
    "prop-types",
    "react-redux",
    "react-router-dom",
    "redux",
    "redux-thunk"
  ],
  "dev": { // 開發(fā)環(huán)境配置
    "port": 8031, // 開發(fā)環(huán)境端口
    "src": "app", // 開發(fā)環(huán)境監(jiān)聽目錄
    "api": "", // 開發(fā)環(huán)境后端接口地址
    "module": {}, // 開發(fā)環(huán)境的模塊包
    "is_eslint": false // 開發(fā)環(huán)境是否開啟eslint校驗
  },
  "test": { // 測試環(huán)境配置
    "module": {}, // 測試環(huán)境的模塊包
    "api": "" // 測試環(huán)境后端接口地址
  },
  "prod": { // 生產(chǎn)環(huán)境配置
    "module": {}, // 生產(chǎn)環(huán)境的模塊包
    "api": "" // 生產(chǎn)環(huán)境后端接口地址
  }
}

app

項目目錄
├── app // 項目業(yè)務(wù)代碼
│   ├── assets // 靜態(tài)文件目錄(圖片、字體等)
│   ├── script // js代碼目錄
│   │   ├── actions // redux action目錄
│   │   ├── componets // react 無狀態(tài)組件目錄
│   │   ├── containers // react 業(yè)務(wù)代碼
│   │   ├── reducers // redux reducer目錄
│   │   ├── util // 工具包目錄
│   │   │   ├── theme.js // antd自定義樣式文件
│   │   ├── Home.js // 首頁
│   │   ├── home.less // 首頁樣式
│   ├── styles // 全局樣式目錄
│   ├── index.js // 項目入口文件
│   ├── index.tpl.html // 項目html模版

如上,因為react遵循組件化開發(fā),故我們的業(yè)務(wù)代碼全部寫在containers目錄下,并且模塊的樣式文件、高階組件寫在相對的模塊下,如圖

styles目錄用于存放項目全局的樣式文件,例如全局樣式的變量文件等...

其他
版本管理:

推薦使用gitflow來進行版本的管理,這里不做詳細(xì)描述

前后端分離跨域:

一旦項目采用前后端分離,跨域是所有項目里不可避免的問題,目前跨域的解決方案主要有三種

采用jsonp方式(只支持GET請求)

采用cors方式

采用node中間件方式(需要多帶帶部署nodejs服務(wù))

我們這里采用方式2

java代碼
response.addHeader("Access-Control-Allow-Origin", "*");
response.addHeader("Access-Control-Allow-Credentials", "true");
response.addHeader("Access-Control-Allow-Headers","Content-Type,Content-Token,Content-User,X-Requested-With");
nodejs 代碼
res.header("Access-Control-Allow-Origin", "*");
res.header("Access-Control-Allow-Headers","Content-Type,Content-Token,Content-User,X-Requested-With");
res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
res.header("X-Powered-By"," 3.2.1")
res.header("Content-Type", "application/json;charset=utf-8");

這種方式還可以自定義請求頭的認(rèn)證信息

不明白的朋友可以去看阮一峰大神的這篇文章

未完待續(xù) 更新于2018-02-26

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/92872.html

相關(guān)文章

  • 前端閱讀 - 收藏集 - 掘金

    摘要:實現(xiàn)不定期更新技巧前端掘金技巧,偶爾更新。統(tǒng)一播放效果實現(xiàn)打字效果動畫前端掘金前端開源項目周報前端掘金由出品的前端開源項目周報第四期來啦。 Web 推送技術(shù) - 掘金騰訊云技術(shù)社區(qū)-掘金主頁持續(xù)為大家呈現(xiàn)云計算技術(shù)文章,歡迎大家關(guān)注! 作者:villainthr 摘自 前端小吉米 伴隨著今年 Google I/O 大會的召開,一個很火的概念--Progressive Web Apps ...

    lingdududu 評論0 收藏0
  • 前端通用國際化解決方案

    摘要:前端通用國際化解決方案背景前端技術(shù)日新月異,技術(shù)棧繁多。接下來針對這幾塊內(nèi)容并結(jié)合日常的開發(fā)流程說明國際化的通用解決方案。 文章首發(fā)于個人blog,歡迎大家關(guān)注。 DI18n 前端通用國際化解決方案 背景 前端技術(shù)日新月異,技術(shù)棧繁多。以前端框架來說有React, Vue, Angular等等,再配以webpack, gulp, Browserify, fis等等構(gòu)建工具去滿足日常的開...

    lingdududu 評論0 收藏0
  • 前端每周清單第 41 期 : Node 與 Rust、OpenCV 的火花,網(wǎng)絡(luò)安全二三事

    摘要:的網(wǎng)站仍然使用有漏洞庫上周發(fā)布了開源社區(qū)安全現(xiàn)狀報告,發(fā)現(xiàn)隨著開源社區(qū)的日漸活躍,開源代碼中包含的安全漏洞以及影響的范圍也在不斷擴大。與應(yīng)用安全是流行的服務(wù)端框架,本文即是介紹如何使用以及其他的框架來增強應(yīng)用的安全性。 showImg(https://segmentfault.com/img/remote/1460000012181337?w=1240&h=826); 前端每周清單專注...

    syoya 評論0 收藏0
  • 前端每周清單半年盤點之 ReactReactNative 篇

    摘要:前端每周清單半年盤點之與篇前端每周清單專注前端領(lǐng)域內(nèi)容,以對外文資料的搜集為主,幫助開發(fā)者了解一周前端熱點分為新聞熱點開發(fā)教程工程實踐深度閱讀開源項目巔峰人生等欄目。與求同存異近日,宣布將的構(gòu)建工具由遷移到,引發(fā)了很多開發(fā)者的討論。 前端每周清單半年盤點之 React 與 ReactNative 篇 前端每周清單專注前端領(lǐng)域內(nèi)容,以對外文資料的搜集為主,幫助開發(fā)者了解一周前端熱點;分為...

    Barry_Ng 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<