摘要:初學,利用進行工程化開發(fā)管理,遇到一些問題,如多頁面處理,跨域代理的設(shè)置,如何同時引入使用。這個命令生成的文件可以放到后端服務(wù)器指定的靜態(tài)文件目錄下,這些就是用來上線的文件。這兩個文件夾下的代碼文件就是為兩個獨立的頁面準備的。
初學react,利用webpack進行工程化開發(fā)管理,遇到一些問題,如多頁面處理,跨域代理的設(shè)置,如何同時引入使用jQuery。第一次試水,簡單寫了一個表格組件。
先照著react官網(wǎng)提供的教程使用create-react-app創(chuàng)建react項目(http://www.css88.com/react/do...)
npm install -g create-react-app create-react-app my-app cd my-app npm start
OK,第一個react程序跑起來了,然后第一個問題來了,這是一個單頁應(yīng)用,按照以往的開發(fā)經(jīng)驗,由于需要開發(fā)的平臺會比較復(fù)雜,需要做成多頁面,如何配置成多頁面呢:
改造一下my-app目錄下的package.json文件(這個文件決定了你前端工程化開發(fā)時候需要安裝的依賴,包括react也是在這里安裝的哦)
附上我的package.json:
{ "name": "my-app", "version": "1.0.0", "description": "pack test", "main": "index.js", "dependencies": { "expose-loader": "^0.7.4", "jquery": "^3.2.1", "webpack": "^3.10.0", "react": "^16.2.0", "react-dom": "^16.2.0", "react-scripts": "1.1.1" }, "devDependencies": { "babel-core": "^6.26.0", "babel-loader": "^7.1.2", "babel-preset-es2015": "^6.24.1", "babel-preset-react": "^6.24.1", "clean-webpack-plugin": "^0.1.16", "css-loader": "^0.28.7", "extract-text-webpack-plugin": "^3.0.0", "file-loader": "^1.0.0", "glob": "^7.1.2", "html-webpack-plugin": "^2.30.1", "postcss-loader": "^2.0.6", "style-loader": "^0.18.2", "url-loader": "^0.5.9", "jquery": "^3.2.1", "webpack": "^3.10.0", "webpack-dev-server": "^2.8.1" }, "scripts": { "start": "webpack-dev-server --open", "build": "webpack" }, "author": "albert", "license": "ISC" }
我們把原來目錄下的node_modules文件夾刪除掉,然后在package.json所在目錄下跑
npm i
就會自動生成node_modules文件夾并安裝我們在package.json里定義的那些依賴了。
package.json里可以看到我要安裝jqeury依賴,后面會聊這個。另外想聊一下的是這一句
"scripts": { "start": "webpack-dev-server --open", "build": "webpack" }
這里我們指定了npm命令腳本,對應(yīng)的運行命令分別是 npm start 和 npm run build(一定要加上run,初學跑的時候沒帶run,一直跑不出來,被這個懵圈了好久o(╥﹏╥)o)
npm start中我們指定了是用webpack的dev server來運行,會啟動一個服務(wù)器。這個開發(fā)的時候用很爽,編輯了代碼保存后會熱更新,前端代碼自動重新構(gòu)建并通知瀏覽器刷新。此時打包的文件是在內(nèi)存中生成的,所以不要費勁去目錄下找了,你根本找不到o( ̄︶ ̄)o
npm run build運行后是用來真正生成webpack打包后的文件的,你可以指定輸出目錄,具體參考webpack.config.js。這個命令生成的文件可以放到后端服務(wù)器指定的靜態(tài)文件目錄下,這些就是用來上線的文件。
圖片描述
再瞥一眼我的webpack.config.js,這個文件是用來告訴webpack按什么樣的方式構(gòu)建前端工程,如何打包等等,用create-react-app命令生成的目錄結(jié)構(gòu)里是沒有這個文件的,需要自己新建一個,放在和package.json同級即可。
先貼一個完整的webpack.config.js,你可以不看,晚點再解釋里面的一些部分。
const webpack = require("webpack"); const glob = require("glob"); const path = require("path"); const HtmlWebpackPlugin = require("html-webpack-plugin"); const ExtractTextPlugin = require("extract-text-webpack-plugin"); const CleanWebpackPlugin = require("clean-webpack-plugin"); const webpackConfig = { entry: {}, output:{ // path:path.resolve(__dirname, "./dist/"), path:path.resolve("C:/wamp64/www/path/"), filename:"[name].[chunkhash:6].js" }, //設(shè)置開發(fā)者工具的端口號,不設(shè)置則默認為8080端口 devServer: { inline: true, port: 8181, proxy: { "/": { target: "http://localhost:80", secure: true, changeOrigin: true } } }, module:{ rules:[ { test:/.js?$/, exclude:/node_modules/, loader:"babel-loader", query:{ presets:["es2015","react"] } }, { test: /.(scss|sass|css)$/, loader: ExtractTextPlugin.extract({fallback: "style-loader", use: "css-loader"}) }, { test: require.resolve("jquery"), use: [{ loader: "expose-loader", options: "jQuery" },{ loader: "expose-loader", options: "$" }] } ] }, plugins: [ new ExtractTextPlugin("[name].[chunkhash:6].css"), new CleanWebpackPlugin( ["path"], { root: "C:/wamp64/www/", verbose: true, dry: false } ) ], }; // 獲取指定路徑下的入口文件 function getEntries(globPath) { const files = glob.sync(globPath), entries = {}; console.log(files) files.forEach(function(filepath) { const split = filepath.split("/"); const name = split[split.length - 2]; entries[name] = "./" + filepath; }); return entries; } const entries = getEntries("src/**/index.js"); Object.keys(entries).forEach(function(name) { webpackConfig.entry[name] = entries[name]; const plugin = new HtmlWebpackPlugin({ filename: name + ".html", template: "./public/index.html", inject: true, chunks: [name] }); webpackConfig.plugins.push(plugin); }) module.exports = webpackConfig;
一.解決多頁面問題
原來的目錄結(jié)構(gòu)如下,
調(diào)整一下目錄結(jié)構(gòu),刪掉原來的src目錄下內(nèi)容,新建兩個文件夾,然后分別添加兩個頁面要用的源文件進去(如果想快速試驗,可以直接把原來的例子中的src的內(nèi)容放到兩個文件夾下)。 這兩個文件夾下的代碼文件就是為兩個獨立的頁面準備的。
我的目錄結(jié)構(gòu)如下,
未完,更新中... (最新更新時間2018/2/27, 這幾天忙著面試,沒有更新,等有空我就寫完他~)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/110117.html
摘要:希望幫助更多的前端愛好者學習。前端開發(fā)者指南作者科迪林黎,由前端大師傾情贊助。翻譯最佳實踐譯者張捷滬江前端開發(fā)工程師當你問起有關(guān)與時,老司機們首先就會告訴你其實是個沒有網(wǎng)絡(luò)請求功能的庫。 前端基礎(chǔ)面試題(JS部分) 前端基礎(chǔ)面試題(JS部分) 學習 React.js 比你想象的要簡單 原文地址:Learning React.js is easier than you think 原文作...
摘要:豆瓣電影版用全家桶仿寫豆瓣電影版。原計劃仿寫完所有頁面,礙于豆瓣的接口有限,實現(xiàn)頁面也有限。由于公開的豆瓣接口具有訪問次數(shù)限制,克隆到本地體驗效果更加端訪問已設(shè)置寬度適配。 douban-movie(豆瓣電影wap版) 用vue全家桶仿寫豆瓣電影wap版。 最近在公司項目中嘗試使用vue,但奈何自己初學水平有限,上了vue沒有上vuex,開發(fā)過程特別難受。 于是玩一玩本項目,算是對相關(guān)...
摘要:熟悉了之后,各種新舊項目,大小項目都能用耍的飛起。使用作為文件中的模板安裝,記住不是,也不用配置,只需在標簽中指定,就可以愉快的使用語法了,比起看起來簡潔多了。 webpack做文件合并 使用構(gòu)建工具非常常用一個功能就是合并js和css文件,gulp和grunt都是編寫相應(yīng)的任務(wù)來完成,轉(zhuǎn)到webpack突然懵逼了,簡單的項目怎么做文件合并呢?其實只需把多個js文件同時引入到main....
摘要:面試題來源于網(wǎng)絡(luò),看一下高級前端的面試題,可以知道自己和高級前端的差距。 面試題來源于網(wǎng)絡(luò),看一下高級前端的面試題,可以知道自己和高級前端的差距。有些面試題會重復(fù)。 使用過的koa2中間件 koa-body原理 介紹自己寫過的中間件 有沒有涉及到Cluster 介紹pm2 master掛了的話pm2怎么處理 如何和MySQL進行通信 React聲明周期及自己的理解 如何...
閱讀 1460·2021-11-22 14:44
閱讀 2843·2021-11-16 11:44
閱讀 3206·2021-10-13 09:40
閱讀 1980·2021-10-08 10:04
閱讀 2363·2021-09-24 10:28
閱讀 2909·2021-09-06 15:02
閱讀 2957·2019-08-30 15:52
閱讀 2392·2019-08-30 13:20