模板項目搭建

  1. create-react-app 創(chuàng)建項目, npm run eject 彈出配置

  2. 替換eslint 規(guī)則為 airbnb

  1. 增加組件熱更新
    -安裝依賴
    https://github.com/gaearon/react-hot-loader/
  1. 增加 Ant Design for React
  1. 增加less支持, 主要是為了antd 的定制主題+按需加載
  • 使用社區(qū)方案
  • https://medium.com/@GeoffMiller/how-to-customize-ant-design-with-react-webpack-the-missing-guide-c6430f2db10f
    • 安裝 less-vars-to-js , 把less變量引入到 less-loader 中做變量替換
      npm install less-vars-to-js --save-dev
    • 安裝 less 與 less-loader
      npm install less less-loader --save-dev
    • 在根目錄新建文件 ant-theme-vars.less
      內(nèi)容為替換主題的變量(例如):
      // Available theme variables can be found in
      // https://github.com/ant-design/ant-design/blob/master/components/style/themes/default.less
      
      @primary-color: #eec988; //<-- our first ant theme override!
      
    • 在config目錄新建文件: antd.theme.js, 內(nèi)容如下:
      const path = require('path');
      const fs = require('fs');
      const lessToJs = require('less-vars-to-js');
      const themeVariables = lessToJs(fs.readFileSync(path.join(process.cwd(), './ant-theme-vars.less'), 'utf8'));
      
      module.exports = themeVariables;
      
    • 修改config/webpack.config.dev.js 和 config/webpack.config.prod.js, css加載部分配置
      test: /\.(css|less)$/,
              use: [
                require.resolve('style-loader'),
                {
                  loader: require.resolve('css-loader'),
                  options: {
                    importLoaders: 2,
                  },
                },
                {
                  loader: require.resolve('postcss-loader'),
                  options: {
                    // Necessary for external CSS imports to work
                    // https://github.com/facebookincubator/create-react-app/issues/2677
                    ident: 'postcss',
                    plugins: () => [
                      require('postcss-flexbugs-fixes'),
                      autoprefixer({
                        browsers: [
                          '>1%',
                          'last 4 versions',
                          'Firefox ESR',
                          'not ie < 9', // React doesn't support IE8 anyway
                        ],
                        flexbox: 'no-2009',
                      }),
                    ],
                  },
                },
                {
                  loader: require.resolve("less-loader"),
                  options: {
                    "modifyVars": require('./antd.theme'),
                  },
                },
              ],
      
  1. 增加 styled-components, 作為 css-in-js 方案
  • 安裝
    npm install --save styled-components
  • 安裝babel插件
    npm install --save-dev babel-plugin-styled-components
    配置babel, 修改 .babelrc, 增加配置項:
    "plugins": ["babel-plugin-styled-components", {
        "displayName": true
      }]
    
  • 安裝webStrom高亮插件,要求 webStrom 2017.2 以上版本
    https://github.com/styled-components/webstorm-styled-components
  1. add flow

轉(zhuǎn)換為propTypes可以在運行時檢查props類型是否正確, 注意有個坑.
需要寫 class x {props: T; } 和 flow 的語法(class x<T>)不一致 (升級一下 eslint-plugin-react 應該可以解決)

  1. eslint + prettier, webStrom 集成 prettier

  2. debugger in IDE

  3. 已增加插件 webpack-dashboard/plugin 推薦使用 electron-webpack-dashboard

// TODO 打包優(yōu)化, common-chunk(公共代碼部分長期緩存), bundle分析, 各種webpack插件的使用
// 發(fā)布部署方案

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末瘫辩,一起剝皮案震驚了整個濱河市壮莹,隨后出現(xiàn)的幾起案子剥扣,更是在濱河造成了極大的恐慌甥材,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鲫凶,死亡現(xiàn)場離奇詭異许布,居然都是意外死亡,警方通過查閱死者的電腦和手機箍铭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進店門泊柬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人诈火,你說我怎么就攤上這事兽赁。” “怎么了?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵刀崖,是天一觀的道長惊科。 經(jīng)常有香客問我,道長亮钦,這世上最難降的妖魔是什么馆截? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮蜂莉,結(jié)果婚禮上蜡娶,老公的妹妹穿的比我還像新娘。我一直安慰自己映穗,他們只是感情好窖张,可當我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蚁滋,像睡著了一般荤堪。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上枢赔,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天澄阳,我揣著相機與錄音,去河邊找鬼踏拜。 笑死碎赢,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的速梗。 我是一名探鬼主播肮塞,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼姻锁!你這毒婦竟也來了枕赵?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤位隶,失蹤者是張志新(化名)和其女友劉穎拷窜,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體涧黄,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡篮昧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了笋妥。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片懊昨。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖春宣,靈堂內(nèi)的尸體忽然破棺而出酵颁,到底是詐尸還是另有隱情嫉你,我是刑警寧澤,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布躏惋,位于F島的核電站幽污,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏其掂。R本人自食惡果不足惜油挥,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一潦蝇、第九天 我趴在偏房一處隱蔽的房頂上張望款熬。 院中可真熱鬧,春花似錦攘乒、人聲如沸贤牛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽殉簸。三九已至,卻和暖如春沽讹,著一層夾襖步出監(jiān)牢的瞬間般卑,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工爽雄, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留蝠检,地道東北人。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓挚瘟,卻偏偏與公主長得像叹谁,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子乘盖,可洞房花燭夜當晚...
    茶點故事閱讀 44,619評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 今天也是有很多故事要講 所以就先把第三天隔過去 以后有機會再講啦焰檩。 很幸運的是店長今天排班只給我排了11到16五個...
    IMaDIME閱讀 285評論 0 0
  • 白百何出軌的新聞已經(jīng)刷爆各大媒體,有人調(diào)侃失戀33天的團隊也太牛逼了吧订框,文章白百何張子萱都挺有能耐析苫。 我記得白百何...
    約里閱讀 784評論 0 2
  • 5月31日《一個廣告人的自白》 【day80盈盈】 當一個廣告人總是盡力站在客戶的角度,以他們的眼光看問題時穿扳,不僅...
    蘇小盈閱讀 135評論 0 0
  • 文/田心小妹 -1- 去學校附近的超市買東西纵揍,回來的時候才發(fā)現(xiàn)電動車沒電了顿乒。無可奈何的我,只得冒著炎炎烈日泽谨,花了二...
    田心小妹閱讀 567評論 4 14