最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 从零开始搭建一个webpack+react项目

    正文概述 掘金(sokach)   2021-01-22   401

    简单的demo

    我们先从一个简单的demo来看看具体的流程:

    初始化

    执行 npm init 创建一个符合node规范的项目,创建之后会成一个package.json项目。

    {
      "name": "tsdemo",
      "version": "1.0.0",
      "description": "",
      "main": "index.js",
      "scripts": {
        "test": "echo \"Error: no test specified\" && exit 1",
      },
      "author": "",
      "license": "ISC",
    }
    
    

    react

    1. 执行 npm i react react-dom 安装 reactreact-dom

    2. 创建页面:

    // ***src/App.tsx***
    
    import React from 'react';
    
    const App: React.FC = () => {
      return (<div>hello, world</div>);
    };
    
    export default App;
    
    // ***src/index.tsx***
    
    import React from 'react';
    import ReactDOM from 'react-dom';
    import App from './App';
    
    ReactDOM.render(<App />, document.getElementById('root'));
    
    // ***src/index.html***
    <!DOCTYPE html>
    <html lang="zh-CN">
    <head>
        <meta charset="utf-8" />
        <meta name="viewport"
            content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
        <title>react-app</title>
    </head>
    <body>
        <div id="root"></div>
    </body>
    </html>
    

    typescript

    1. 执行 npm i typescript -D 安装 typescript

    2. 创建配置文件:

    // tsconfig.json
    {
      "compilerOptions": {
        "outDir": "./dist",	// 输出的目录
        "module": "CommonJS",	// 指定生成哪个模块系统代码: "None", "CommonJS", "AMD", "System", "UMD", "ES6"或 "ES2015"
        "target": "ES2015",	// 指定 ES 目标版本,默认 ES3
        "jsx": "react",	// 在 .tsx 文件里支持 jsx
        "declaration": true,	// 生成相应的 .d.ts 文件
        "removeComments": true,	// 删除所有注释,除了以 /!* 开头的版权信息。
      },
      "include": [
        "src/**/*",	 // 需要编译的文件
      ],
      "exclude": [
        "node_modules", // 不编译此文件夹下的文件
      ],
    }
    

    webpack

    1. 执行 npm install webpack webpack-cli -S -D

    webpack 用来打包,webpack-cliwebpack 命令可以执行

    1. 项目中有.tsx文件,所以要安装loader 进行处理:执行 npm install ts-loader --save-dev 安装 ts-loader.tsx文件进行打包。并进行如下配置。

    2. 创建配置文件:

    // ***webpack.config.js***
    const path = require('path')
    
    module.exports = {
        mode: 'development',  // 模式,当前为开发模式,还有个生产模式,生产模式会自动压缩编译后代码到一行
        entry: './src/index.tsx',
        module: {
            rules: [
                {
                    test: /\.tsx?$/,    // ts-loader是官方提供的处理tsx的文件
                    use: 'ts-loader',
                    exclude: /node_modules/
                }
            ]
        },
        resolve:{
        	// 打包的时候报错:Module not found :Error : can't resolve 'App'
        	// 我们引入组件的时候,并没有加后缀(.tsx),
        	// 此配置会按顺序为我们找App.js App.jsx...找到就返回,找不到会报错
            extensions: ['.js', '.jsx', '.ts', '.tsx', '.css', '.less', '.scss']
        },
        output:{
            filename:'bundle.js',
            path:path.resolve(__dirname,'dist')
        }
    }
    

    配置

    最后在package.json文件中,配置如下

    {
      "name": "tsdemo",
      "version": "1.0.0",
      "description": "",
      "main": "index.js",
      "scripts": {
        "test": "echo \"Error: no test specified\" && exit 1",
        "build": "webpack" // 执行 npm run build 相当于 npx webpack
      },
      "author": "", 
      "license": "ISC",
      "dependencies": {
        "react": "^17.0.1",
        "react-dom": "^17.0.1"
      },
      "devDependencies": {
        "ts-loader": "^8.0.14",
        "typescript": "^4.1.3",
        "webpack": "^5.15.0",
        "webpack-cli": "^4.3.1"
      }
    }
    
    

    之后执行npm run build,就可以看到dist文件下打包好的文件。一个小的demo就完成了。

    plugin

    经过上边的一些列操作之后,我们看到了dist下打包好的文件,但是并没有看到页面。可以在 vscode 中安装插件 open in browser ,之后在 index.html 中右击选中 open in default browser,就可以看到浏览器中出现了html页面。

    但是存在一个新的问题:并没有显示 App 组件中的东西(hello world)。

    我们需要在 index.html中引入打包好的文件(bundle.js):

     <script src="../dist/bundle.js"></script>
    

    删除掉dist文件夹,从新打包 npm run build

    你会发现依旧没有任何东西,打开控制台,会报错:

    Cannot read property 'createElement' of undefined
    Consider adding an error boundary to your tree to customize error handling behavior.
    

    这是因为 reactreact-dom 引入不规范导致的,将所有引入改为:

    import * as React from 'react'
    import * as ReactDom from 'react-dom'
    

    前边的过程中,存在三个问题:

    1. 每次打包都要手动删除dist 文件夹
    2. 手动添加打包后的 bundle.js 文件
    3. html 页面并没有跑在 localhost 上,并且需要手动打开

    接下来就逐步解决这些问题。

    clean-webpack-plugin

    clean-webpack-plugin 的作用是在打包之前删除output.path下的所有内容之后再进行打包。所以不用传递参数。

    1. 安装 :npm install --save-dev clean-webpack-plugin

    2. 引入并配置:

    const { CleanWebpackPlugin } = require('clean-webpack-plugin');
    
    module.exports = {
    	plugins:[        
            new CleanWebpackPlugin()
        ],
    }
    

    这样就不用每次打包前手动删除dist文件夹了。

    html-webpack-plugin

    自行点击标题进入官网按照教程下载就好。

    HtmlWebpackPlugin的作用是当打包完成时,以src/index.html文件为模板,生成index.html文件,并将打包好的js文件注入到里边。

    const HtmlWebpackPlugin = require('html-webpack-plugin');
    module.exports = {
    	plugins:[        
            new HtmlWebpackPlugin({
                template: './src/index.html'
            })
        ],
    }
    

    打包后你会看到dist下会有个html文件。并且将打包好的bundle.js文件自动添加。打开这个HTML,我们可以看到正常的页面。这样我们就不用逐个把打包后的文件添加到HTML文件中(所入口打包的话可能会产生很多打包后的文件,逐个添加很麻烦)。

    webpack-dev-server

    看官网自行安装。

    module.exports = {
    	devServer:{
            contentBase:'./dist', //借助devServer生成服务器放到dist目录下,但是dist目录下看不到任何东西,在内存中,这样可以提升速度
            open:true,  //可以自动打开网址不必手动打开
        },
    }
    

    配置命令:

      "scripts": {
        "build": "webpack",
        "start": "webpack serve"
        
        // "start": "webpack-dev-server" 
        // 报错Error: Cannot find module 'webpack-cli/bin/config-yargs'
        // code: 'MODULE_NOT_FOUND'
      },
    

    运行 npm run start你会发现浏览器会自动打开窗口,并且当你修改完代码的啥时候,网页自动刷新。

    loader

    .jsx文件

    执行npm install -D babel-loader @babel/core @babel/preset-env @babel/preset-react

    根目录创建.babelrc文件并配置:

    {
        "presets": ["@babel/preset-react","@babel/preset-env"]
    }
    

    配置webpack:

    module:{
    	rules:[
    		{
              test: /\.jsx?$/,
              exclude: /node_modules/,
              use: {loader: "babel-loader"}
             }
    	]
    }
    

    起源地下载网 » 从零开始搭建一个webpack+react项目

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元