详解使用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 相关文章推荐
textarea不能通过maxlength属性来限制字数的解决方法
Sep 01 Javascript
一个不错的仿携程自定义数据下拉选择select
Sep 01 Javascript
JQuery 给元素绑定click事件多次执行的解决方法
Sep 09 Javascript
jquery中change()用法实例分析
Feb 06 Javascript
又一款js时钟!transform实现时钟效果
Aug 15 Javascript
JavaScript浏览器对象模型BOM(BrowserObjectModel)实例详解
Nov 29 Javascript
Angular.js中angular-ui-router的简单实践
Jul 18 Javascript
React Native 自定义下拉刷新上拉加载的列表的示例
Mar 01 Javascript
详解微信小程序网络请求接口封装实例
May 02 Javascript
vue+element表格导出为Excel文件
Sep 26 Javascript
微信小程序学习总结(三)条件、模板、文件引用实例分析
Jun 04 Javascript
vue 全局封装loading加载教程(全局监听)
Nov 05 Javascript
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基础知识:类与对象(3) 构造函数和析构函数
2006/12/13 PHP
PHP中soap用法示例【SoapServer服务端与SoapClient客户端编写】
2018/12/25 PHP
JSON 学习之JSON in JavaScript详细使用说明
2010/02/23 Javascript
5款JavaScript代码压缩工具推荐
2014/07/07 Javascript
jQuery判断checkbox是否选中的3种方法
2014/08/12 Javascript
JavaScript基础知识学习笔记
2014/12/02 Javascript
js光标定位文本框回车表单提交问题的解决方法
2015/05/11 Javascript
在AngularJS应用中实现一些动画效果的代码
2015/06/18 Javascript
浅析JavaScript Array和string的转换(推荐)
2016/05/20 Javascript
IScroll5 中文API参数说明和调用方法
2016/05/21 Javascript
BootStrap 实现各种样式的进度条效果
2016/12/07 Javascript
Vue中fragment.js使用方法详解
2017/03/09 Javascript
详解axios在vue中的简单配置与使用
2017/05/10 Javascript
Vue filter介绍及详细使用
2018/04/04 Javascript
简单了解vue.js数组的常用操作
2019/06/17 Javascript
微信小程序页面间传递数组对象方法解析
2019/11/06 Javascript
vue实现短信验证码输入框
2020/04/17 Javascript
[38:32]DOTA2上海特级锦标赛A组资格赛#2 Secret VS EHOME第二局
2016/02/26 DOTA
Python中关于字符串对象的一些基础知识
2015/04/08 Python
Python中取整的几种方法小结
2017/01/06 Python
python脚本开机自启的实现方法
2019/06/28 Python
使用pycharm在本地开发并实时同步到服务器
2019/08/02 Python
使用PyTorch实现MNIST手写体识别代码
2020/01/18 Python
python使用Thread的setDaemon启动后台线程教程
2020/04/25 Python
解决Keyerror ''acc'' KeyError: ''val_acc''问题
2020/06/18 Python
Fairyseason:为个人和批发商提供女装和配件
2017/03/01 全球购物
We Fashion荷兰:一家国际时装公司
2018/04/18 全球购物
舒适的豪华鞋:Taryn Rose
2018/05/03 全球购物
.net C#面试题
2012/08/28 面试题
2014企业领导班子四风对照检查材料思想汇报
2014/09/17 职场文书
部门群众路线教育实践活动对照检查材料思想汇报
2014/10/07 职场文书
县级领导干部开展党的群众路线教育实践活动工作汇报
2014/10/25 职场文书
武侯祠导游词
2015/02/04 职场文书
索赔员岗位职责
2015/02/15 职场文书
困难补助申请报告
2015/05/19 职场文书
安全教育观后感
2015/06/17 职场文书