react打包后图片丢失_使用 webpack 搭建 React 项目

fa7de314b684f334eea22e7dcc66abb0.png
简评:相信很多开发者在入门 react 的时候都是使用 create-react-app 或 react-slingshot 这些脚手架来快速创建应用,当有特殊需求,需要修改 eject 出来的 webpack 配置文件时,面对各种配置项不知如何下手,本文会介绍如何使用 webpack 手动搭建一个 react 项目。

新建工程

  1. 先新建一个 demo 项目,项目目录结构为:

7a272cbeab24399782854dadf5f3555e.png

2. 在工程根目录新建 index.html 文件

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>My React Boilerplate</title>
</head>
<body><div id="app"></div>
</body>
</html>

3. 安装 react react-dom 依赖:

npm i react react-dom

4. 创建应用 /src/components/App.js

import React, { Component } from 'react'class App extends Component {render() {return (<div><h1>Welcome to My Starter App</h1></div>)}
}export default App

5. 创建 /src/index.js

import React from 'react'
import ReactDOM from 'react-dom'
import App from './components/App'import './styles/style.sass'ReactDOM.render(<App />,document.getElementById('app')
)

以上就是我们的 demo 工程。如果我们通过 react-create-app 上面的代码已经可以正常运行了,但是现在的代码没有进行任何的处理无法直接在浏览器中运行。

我们需要将 jsx 和 ES6 代码转换成浏览器中可运行的代码。

Babel

Babel 就是为了处理上面的问题,我们可以使用 JavaScript 最新的语法特性,然后使用 babel 插件对代码进行转换以达到最大的兼容性。首先安装相关依赖:

npm i babel-cli babel-core babel-preset-env babel-preset-react babel-preset-stage-2--save-dev

然后在工程跟目录创建一个 .babelrc 配置文件,内容为:

{"presets": ["env", "react", "stage-2"]
}

参数说明:

  • env:表示包含 babel-preset-es2015,babel-preset-es2016babel-preset-es2017,意味着我们可以编写 ES6,ES7,和 ES8 的代码。
  • react:这个选项指明处理 React 的相关不能,比如 JSX。
  • stage-2:运行我们使用当前处于阶段 2 或更高阶段的 javascript 功能更多信息可以参考 TC39。

测试

刚才已经创建了 App.js 的 React 组件,并且安装配置了 babel,为了代码的健壮性我们再添加测试环境这里使用 Jest 和 Enzyme。

  1. 安装依赖:
npm i jest enzyme enzyme-adapter-react-16 react-test-renderer --save-dev

2. 然后创建 /test/enzyme.setup.js 文件,添加如下代码:

import Enzyme from 'enzyme'
import Adapter from 'enzyme-adapter-react-16'Enzyme.configure({adapter: new Adapter()
})

3. 在 package.json 中添加 jest 功能字段:

{
...,
"jest": {"setupTestFrameworkScriptFile": "./test/enzyme.setup.js"},
...
}

4. 编写测试代码:

创建 /test/App.test.js 文件,为 App 组件编写测试代码:

import App from '../src/components/App'
import React from 'react'
import { shallow } from 'enzyme'describe('App', () => {test('should match snapshot', () => {const wrapper = shallow(<App />)expect(wrapper.find('h1').text()).toBe('Welcome to My Starter App')expect(wrapper).toMatchSnapshot})
})

当执行 jest ./test 来启动测试代码。

为了方便可以将他添加到 package.json 中:

{...,"scripts": {"test": "jest ./test"}
}

Webpack

webpack 可以将我们工程代码打包到一个文件中,比如我们有很多个 js 代码相互依赖,打包的时候会将这些 js 文件合并成一个文件,还可以使用插件来预处理和处理最终生成的代码。

  1. 安装 webpack 依赖:
npm i webpack --save-dev

webpack 运行的时候回自动找到项目根目录的 webpack.config.js 文件,所以我们可以先创建这个文件,并加入如下代码。

const path = require('path')module.exports = {entry: {main: './src/index.js'},output: {filename: '[name].[hash].js',path: path.resolve('./dist'),}
}

entry 指明入口文件,webpack 会从这个文件开始连接所有的依赖。 output 指明打包后的文件存放的位置。

Webpack loaders

loaders 可以让 webpack 处理很多不同格式的文件(例如:图片、CSS 、 JSX ...),

这里我们没有用到图片和 CSS 资源,只需要处理 ES6 和 JSX,只需要 babel-loader。

  1. 安装 babel-loader:
npm i babel-loader --save-dev

然后在 webpack.config.js 文件中添加打包规则添加后代码如下:

const path = require('path')module.exports = {entry: {main: './src/index.js'},output: {filename: '[name].[hash].js',path: path.resolve('./dist'),},module: {rules: [{test: /.js$/,exclude: ['node_modules'],use: [{ loader: 'babel-loader' }],}]
}

2. 如果需要使用 Sass 和 SCSS,我们需要其他的 loader。

npm i node-sass sass-loader style-loader css-loader --save-dev

然后在 webpack.config.js 中添加 sass 和 scss 文件的转换规则,最终代码如下:

const path = require('path')module.exports = {entry: {main: './src/index.js'},output: {filename: '[name].[hash].js',path: path.resolve('./dist'),},module: {rules: [{test: /.js$/,exclude: ['node_modules'],use: [{ loader: 'babel-loader' }],},{test: /.s(a|c)ss$/,use: [{loader: 'style-loader'}, {loader: 'css-loader'}, {loader: 'sass-loader'}],}]
}

现在可以在工程中使用 Sass 了,创建 /src/styles/style.sass 文件,并添加如下代码:

bodyfont-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serifcolor: whitebackground: black

然后在 index.js 带人 style.sass:

import React from 'react'
import ReactDOM from 'react-dom'
import App from './components/App'import './styles/style.sass'ReactDOM.render(<App />,document.getElementById('app')

3. 现在有一个需求,我们需要将打包后的 js 文件自动导入到 html 文件中,我们可以使用 html-webpack-plugin 自动完成这部分内容。

安装 html-webpack-plugin:

npm i html-webpack-plugin --save-dev

然后在 webpack.config.js 中导入这个插件:

const CleanWebpackPlugin = require('clean-webpack-plugin')
const path = require('path')module.exports = {entry: {main: './src/index.js'},output: {filename: '[name].[hash].js',path: path.resolve('./dist'),},module: {rules: [{test: /.js$/,exclude: ['node_modules'],use: [{ loader: 'babel-loader' }],},{test: /.s(a|c)ss$/,use: [{loader: 'style-loader'}, {loader: 'css-loader'}, {loader: 'sass-loader'}],}]},plugins: [new HtmlWebPackPlugin({template: 'index.html'})]
}

当每次 build 的时候的时候会在 dist 目录中生成打包后的文件,我们需要打包时清除这些内容可以使用 clean-webpack-plugin 插件:

npm i clean-webpack-plugin --save-dev

在 webpack.config.js 中添加 clean-webpack-plugin:

const CleanWebpackPlugin = require('clean-webpack-plugin')
const HtmlWebPackPlugin = require('html-webpack-plugin')
const path = require('path')module.exports = {entry: {main: './src/index.js'},output: {filename: '[name].[hash].js',path: path.resolve('./dist'),},module: {rules: [{test: /.js$/,exclude: ['node_modules'],use: [{ loader: 'babel-loader' }],},{test: /.s(a|c)ss$/,use: [{loader: 'style-loader'}, {loader: 'css-loader'}, {loader: 'sass-loader'}],}]},plugins: [new HtmlWebPackPlugin({template: 'index.html'}),new CleanWebpackPlugin(['dist']),]
}

所有的 plugin 和 loader 已经加载完了,为了方便我们开发,还需要 webpack 开发服务器,这样我们就可以实时查看代码修改的效果了。

npm i webpack-cli webpack-dev-server --save-dev

在 webpack.config.js 中添加 devServer 字段:

const CleanWebpackPlugin = require('clean-webpack-plugin')
const HtmlWebPackPlugin = require('html-webpack-plugin')
const path = require('path')module.exports = {entry: {main: './src/index.js'},output: {filename: '[name].[hash].js',path: path.resolve('./dist'),},module: {rules: [{test: /.js$/,exclude: ['node_modules'],use: [{ loader: 'babel-loader' }],},{test: /.s(a|c)ss$/,use: [{loader: 'style-loader'}, {loader: 'css-loader'}, {loader: 'sass-loader'}],}]},plugins: [new HtmlWebPackPlugin({template: 'index.html'}),new CleanWebpackPlugin(['dist']),],devServer: {host: 'localhost',port: 3000,open: true}
}

为了方便运行,可以将 webpack-dev-server 命令添加到 package.json 中:

{..."scripts": {"start": "webpack-dev-server","test": "jest ./test"},
}

现在只需要 npm start 就可以查看 demo 的运行效果,到这里 react webpack 项目开发环境已经算是搭建完成。

但是这个配置没有对生产环境做区分,也就是说生产环境的代码和开发环境代码一样,但实际开发中往往需要对生产环境代码做优化比如(压缩 js代码,修改变量名和方法名),在开发环境中为了编译调试又不希望优化这部分内容。我们可以将两种环境区分开来。

这个时候有可以用到这个插件 webpack-merge:

npm i webpack-merge --save-dev

现在我们可以将原来的 webpack 配置文件分离成三个文件,

webpack.common.js 存放公共配置项:

const CleanWebpackPlugin = require('clean-webpack-plugin')
const HtmlWebPackPlugin = require('html-webpack-plugin')
const path = require('path')module.exports = {entry: {main: './src/index.js'},output: {filename: '[name].[hash].js',path: path.resolve('./dist'),},module: {rules: [{test: /.js$/,exclude: ['node_modules'],use: [{ loader: 'babel-loader' }],},{test: /.s(a|c)ss$/,use: [{loader: 'style-loader'}, {loader: 'css-loader'}, {loader: 'sass-loader'}],}]},plugins: [new HtmlWebPackPlugin({template: 'index.html'}),new CleanWebpackPlugin(['dist']),]
}

webpack.dev.js 在通用配置项基础上添加开发环境配置项:

const merge = require('webpack-merge');
const common = require('./webpack.common.js');module.exports = merge(common, {mode: 'development',devServer: {host: 'localhost',port: 3000,open: true}
})

webpack.prod.js 在通用配置项基础上中添加生成环境配置项:

const merge = require('webpack-merge');
const common = require('./webpack.common.js');module.exports = merge(common, {mode: 'production',
})

最后在 package.json 中添加生产环境打包脚本:

{..."scripts": {"build": "webpack --config webpack.prod.js","start": "webpack-dev-server --config webpack.dev.js","test": "jest ./test"},
}
原文:How to build your own React boilerplate

极光日报,极光开发者旗下媒体。

每天导读三篇英文技术文章。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/490005.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

揭秘5G+AI时代的机器人世界!七大核心技术改变人类生活【附下载】| 智东西内参...

来源&#xff1a; 智东西AI 和 5G 与机器人技术结合&#xff0c;正在不断催生新的消费电子品类。AI 解决机器理解世界&#xff0c;以及人机交互的问题。5G 拓展机器人的活动边界&#xff0c;并为机器人提供更大的算力和存储空间&#xff08;云协作机器人&#xff09; 。根据 IF…

TSQL编程

1.索引添加索引&#xff0c;设计界面&#xff0c;在任何一列前右键--索引/键--点击进入添加某一列为索引 2.视图 视图就是我们查询出来的虚拟表创建视图&#xff1a;create view 视图名 as SQL查询语句,分组&#xff0c;排序&#xff0c;in 等都不能写视图的用法&#xff1a; s…

python方向键控制角色_用python和pygame游戏编程入门-控制角色移动

在上一节中我们知道了事件&#xff0c;以及如何捕捉键盘事件进行响应&#xff0c;本届我们结合第一节何上一节的内容&#xff0c;做一个用键盘控制角色移动的功能&#xff0c;代码如下&#xff1a; #!/usr/bin/env python #指定图像文件名称 background_image_filename ./img/…

arcgis fishnet 单位_ArcGIS中使用Create Fishnet生成格网

ArcGIS中使用Create Fishnet生成格网1.如果单元格的宽和高定义为0&#xff0c;那么必须指定行与列的数目以及格网对角的坐标2.格网的范围可以手动输入&#xff0c;也可以引用已有数据为模板。如果输入一个模版&#xff0c;格网的起始坐标和Y轴的坐标就被自动填充了&#xff0c;…

让人工智能有情感的秘诀!清华权威报告看透情感计算【附下载】

来源&#xff1a; 智东西40 多年前&#xff0c;诺贝尔奖得主 Herbert Simon 在认知心理学方面强调&#xff0c;解决问题论要结合情感的影响。情感的识别和表达对于信息的交流和理解是必需的&#xff0c;也是人类最大的心理需求之一。人类的认知、行为等几乎都要受到情感的驱动&…

端口扫描的目的

端口扫描的目的是扫描大范围的主机连接一系列的 TCP 端口&#xff0c;判断主机开放了哪些服务&#xff0c;这些开放的端口往往与一定的服务相对应&#xff0c;通过这些开放的端口&#xff0c;就能了解主机运行的服务&#xff0c;然后就可以进一步整理和分析这些服务可能存在的漏…

记录用户转成超级用户的文件名字_一分钟了解Linux用户

Linux系统是一个多用户多任务的分时操作系统&#xff0c;任何一个要使用系统资源的用户&#xff0c;都必须首先向系统管理员申请一个账号&#xff0c;然后以这个账号的身份进入系统。用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪&#xff0c;并控制他们对系统资…

桥接模式和nat模式

一、桥接模式&#xff08;bridged networking&#xff09; 在桥接模式下&#xff0c;VMWare虚拟出来的操作系统就像是局域网中一台独立的主机&#xff0c;它能够访问网内任何一台机器。 在桥接模式下&#xff0c;你必须手工为虚拟系统配置IP地址、子网掩码&#xff0c;并且还要…

四维图新地图坐标_移动端地图技术分享

本人现就职于国内某地图导航公司&#xff0c;这篇文章是我前段时间在公司组织技术分享的一个PPT&#xff0c;文章内容也主要由这个PPT的内容为主&#xff0c;通过这篇文章可以很好的帮你了解地图导航这个行业的相关技术。PPT内容主要包括地图相关专业知识、百度和高德SDK整体框…

重磅!2019年诺贝尔生理学或医学奖揭晓,“细胞感知氧气通路”摘得桂冠

来源&#xff1a;奇点网北京时间2019年10月7日17点30分&#xff0c;2019年诺贝尔生理学或医学奖揭晓&#xff0c;得主为William G. Kaelin Jr&#xff0c;Peter J. Ratcliffe和Gregg L. Semenza&#xff0c;获奖理由为“他们发现了细胞如何感知和适应氧气供应”。William G. Ka…

HTTP深入浅出 http请求

HTTP(HyperText Transfer Protocol)是一套计算机通过网络进行通信的规则。计算机专家设计出HTTP&#xff0c;使HTTP客户&#xff08;如Web浏览器&#xff09;能够从HTTP服务器(Web服务器)请求信息和服务&#xff0c;HTTP目前协议的版本是1.1.HTTP是一种无状态的协议&#xff0c…

大一python基础编程试卷_2020大学慕课Python编程基础试题及答案

2020大学慕课Python编程基础试题及答案更多相关问题 四川总面积48.6万平方公里&#xff0c;居全国第&#xff08;&#xff09;位。 国民经济恢复是在() 马化腾是独自创立了腾讯公司 智慧职教: 颈静脉搏动可见于 马化腾是独自创立了腾讯公司 下列各项中&#xff0c;对于会计核算…

vue 找回密码_vue实现个人信息查看和密码修改功能

下面一段代码给大家介绍vue实现个人信息查看和密码修改功能&#xff0c;具体代码如下所述&#xff1a;//用了element组件&#xff0c;自己要加载和引入保存保存//这些不要在意&#xff0c;这些是我们自定义的接口&#xff0c;用的时候就直接拿来了import {fetchall,fetchbyid,f…

世界十大最美方程式

来源&#xff1a;数学职业家自从科学诞生后&#xff0c;不可避免地就会用到方程式&#xff0c;这些方程式以其独特的作用服务于人类的生产创造以及各门学科。而最近几百年的时间&#xff0c;更是方程式数量极大增加的时候&#xff0c;同时也是科学技术突飞猛进的年代。从侧面看…

160826、浏览器渲染页面过程描述,DOM编程技巧以及重排和重绘

一、浏览器渲染页过程描述 1、浏览器解析html源码&#xff0c;然后创建一个DOM树。 在DOM树中&#xff0c;每一个HTML标签都有一个对应的节点(元素节点),并且每一个文本也都有一个对应的节点(文本节点)。 DOM树的根节点就是documentElement&#xff0c;对应的是html标签。 2、浏…

小程序 pagescrollto_微信小程序学习笔记(三)-- 首页及详情页开发

一、常用组件在上一个章节中讲解了封装请求数据的模块&#xff0c;在此处请求轮播图的数据1.首页轮播图数据的请求以及渲染1.1 轮播图数据的请求 pages/home/home.jsimport 2 使用组件 - 视图容器 - swiper滑块视图容器。其中只可放置swiper-item组件&#xff0c;否则会导致未定…

云计算与边缘计算协同 九大应用场景

来源&#xff1a;物联网报告中心前言2019 年边缘计算备受产业关注&#xff0c;一度引起了资本市场的投资热潮&#xff0c;很多人把2019 年称作边缘计算的元年。理性来看&#xff0c;造成如此火爆局势难免有一些炒作因素在推波助澜&#xff0c;毕竟边缘计算的概念存世也已多年。…

cat3 utp是不是网线_网线/双绞线上各标识CAT, AWG, PR, UTP/STP/FTP/SFTP的含义

CAT5, CAT5e, CAT6表示网线类别, 常见的有 CAT5, CAT5e, CAT6分别表示五类, 超五类, 六类网线24AWG, 26AWGAmerican Wire Gauge是美制电线标准, 表示电缆直径. AWG值是导线厚度(以英寸计)的函数, 24AWG约为0.511mm&#xff0c;4pr表示有四对双绞线UTPUnshielded Twisted Pair 非…

Wireshark过滤器表达式的规则

1、抓包过滤器语法和实例 抓包过滤器类型Type&#xff08;host、net、port&#xff09;、方向Dir&#xff08;src、dst&#xff09;、协议Proto&#xff08;ether、ip、tcp、udp、http、icmp、ftp等&#xff09;、逻辑运算符&#xff08;&& 与、|| 或、&#xff01;非&…

《深入浅出WPF》学习笔记之深入浅出话属性

依赖属性是一种可以从父级元素继承&#xff0c;并且可以通过Binding从数据源获取&#xff0c;当从父级继承时不占用内存的属性系统。拥有依赖属性的对象称为依赖对象。WPF允许在创建对象时并不分配用于存储数据的空间&#xff0c;而在需要时实时分配空间或直接借用父级数据&…