详解使用WebPack搭建React开发环境


Posted in Javascript onAugust 06, 2019

第一步、基础环境

初始化

项目初始化

npm init -y

安装webpack

npm i webpack

安装react

npm i react react-dom -s

项目基础框架

入口文件(src/index.js)

import React from 'react'
import {render} from 'react-dom'
import App from './App'
render(<App/>,document.getElementById('root'))

主组件(src/App.js)

import React,{Component} from 'react'
class App extends Component{
  constructor(){
    super()
  }
  redner(){
    return(
      <div>
        App Module
      </div>
    )
  }
}

webpack.config.js

const path = require('path')
const StyleLintPlugin = require('stylelint-webpack-plugin')
const STYLELINTENABLE = true
module.exports = {
  mode:'development',
  entry:'./src/index.js',
  output:{
    path:path.resolve(__dirname,'build'),
    filename:'bundle.js'
  },
  module:{
    rules:[
      //处理js/jsx
      {
        test:/\.jsx?/i,
        use:{
          loader:'bebel-loader',
          options:{
            presets:['@babel/preset-react']
          }
        }
      },
      //处理css
      {
        test:/\.css$/i,
        use:['style-loader','css-loader',{
          loader:'postcss-loader',
          options:{
            plugins:require('autoprefixer')
          }
        }]
      },
      //处理图片资源
      {
        test:/\.(png|jpg|gif)$/i,
        use:{
          loader:'url-loader',
          options:{
            outputPath:'imgs/',
            limit:10*1024
          }
        }
      },
      //处理字体文件
      {
        test:/\.(eot|svg|ttf|woof|woof2)$/i,
        use:{
          loader:'url-loader',
          options:{
            outputPath:'fonts/',
            limit:10*1024
          }
        }
      },
      //less
      {
        test:/\.less$/i,
        use:['style-loader','css-loader','less-loader']
      },

    ]
  },
  devtool:'source-map',
  plugins:[
    ...STYLELINTENABLE ?[
      new StyleLintPlugin({
        files:['**/*.css','**/*.less','**/*.js','**/*.html','**/*.vue','**/*.scss']
      })
    ]:[]
  ]
}

webpack.config.js

"stylelint": {
  "extends": "stylelint-config-standard"
 },
 "browserslist":[
  "> 0.5%",//市场占有率大于百分之零点5
  "last 2 version",//最后两个版本
  "not dead"//还没有die
 ]

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
关于捕获用户何时点击window.onbeforeunload的取消事件
Mar 06 Javascript
JS trim去空格的最佳实践
Oct 30 Javascript
javascript中slice(),splice(),split(),substring(),substr()使用方法
Mar 13 Javascript
遮罩层点击按钮弹出并且具有拖动和关闭效果(两种方法)
Aug 20 Javascript
JS监听微信、支付宝等移动app及浏览器的返回、后退、上一页按钮的事件方法
Aug 05 Javascript
各式各样的导航条效果css3结合jquery代码实现
Sep 17 Javascript
JSON 必知必会 观后记
Oct 27 Javascript
Angular2入门--架构总览
Mar 29 Javascript
node实现的爬虫功能示例
May 04 Javascript
三种Webpack打包方式(小结)
Sep 19 Javascript
element-ui树形控件后台返回的数据+生成组织树的工具类
Mar 05 Javascript
如何在vue中使用video.js播放m3u8格式的视频
Feb 01 Vue.js
vue-cli3+typescript新建一个项目的思路分析
Aug 06 #Javascript
Vue 中可以定义组件模版的几种方式
Aug 06 #Javascript
angularjs请求数据的方法示例
Aug 06 #Javascript
通过js示例讲解时间复杂度与空间复杂度
Aug 06 #Javascript
Flutter 超实用简单菜单弹出框 PopupMenuButton功能
Aug 06 #Javascript
JS中如何轻松遍历对象属性的方式总结
Aug 06 #Javascript
VUE组件中的 Drawer 抽屉实现代码
Aug 06 #Javascript
You might like
php自动加载机制的深入分析
2013/06/08 PHP
解析使用substr截取UTF-8中文字符串出现乱码的问题
2013/06/20 PHP
PHP array_multisort() 函数的深入解析
2013/06/20 PHP
提高PHP编程效率的方法
2013/11/07 PHP
PHP empty函数报错解决办法
2014/03/06 PHP
PHP二进制与字符串之间的相互转换教程
2016/10/14 PHP
php抛出异常与捕捉特定类型的异常详解
2016/10/26 PHP
Javascript WebSocket使用实例介绍(简明入门教程)
2014/04/16 Javascript
推荐25个超炫的jQuery网格插件
2014/11/28 Javascript
IScroll5 中文API参数说明和调用方法
2016/05/21 Javascript
原生JS实现图片网格式渐显、渐隐效果
2017/06/05 Javascript
Vue2.5通过json文件读取数据的方法
2018/02/27 Javascript
浅析Visual Studio Code断点调试Vue
2018/02/27 Javascript
解决vue build打包之后首页白屏的问题
2018/03/06 Javascript
浅谈webpack打包之后的文件过大的解决方法
2018/03/07 Javascript
详解webpack2异步加载套路
2018/09/14 Javascript
BootStrap中的模态框(modal,弹出层)功能示例代码
2018/11/02 Javascript
vue路由守卫及路由守卫无限循环问题详析
2019/09/05 Javascript
webpack优化之代码分割与公共代码提取详解
2019/11/22 Javascript
解决在Vue中使用axios POST请求变成OPTIONS的问题
2020/08/14 Javascript
[49:13]DOTA2上海特级锦标赛C组资格赛#1 OG VS LGD第一局
2016/02/27 DOTA
对Python3中的print函数以及与python2的对比分析
2018/05/02 Python
深入了解和应用Python 装饰器 @decorator
2019/04/02 Python
python爬取Ajax动态加载网页过程解析
2019/09/05 Python
屏蔽Django admin界面添加按钮的操作
2020/03/11 Python
CSS3中的@keyframes关键帧动画的选择器绑定
2016/06/13 HTML / CSS
用HTML5中的Canvas结合公式绘制粒子运动的教程
2015/05/08 HTML / CSS
英国儿童图书网站:Scholastic
2017/03/26 全球购物
阿玛尼美妆加拿大官方商城:Giorgio Armani Beauty加拿大
2017/10/24 全球购物
小学岗位竞聘方案
2014/01/22 职场文书
就业推荐表自我鉴定
2014/03/21 职场文书
快餐公司创业计划书
2014/04/29 职场文书
班级口号大全
2014/06/09 职场文书
幼儿园校园小喇叭广播稿
2014/10/17 职场文书
就业推荐表自我评价范文
2015/03/02 职场文书
Java多线程并发FutureTask使用详解
2022/06/28 Java/Android