详解使用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 相关文章推荐
网页和浏览器兼容性问题汇总(draft1)
Jun 01 Javascript
JS下高效拼装字符串的几种方法比较与测试代码
Apr 15 Javascript
两种常用的javascript数组去重方法思路及代码
Mar 26 Javascript
js 针对html DOM元素操作等经验累积
Mar 11 Javascript
jquery,js简单实现类似Angular.js双向绑定
Jan 13 Javascript
Vue+axios 实现http拦截及路由拦截实例
Apr 25 Javascript
Angular项目中$scope.$apply()方法的使用详解
Jul 26 Javascript
js实现Tab选项卡切换效果
Jul 17 Javascript
vuex页面刷新后数据丢失的方法
Jan 17 Javascript
vue.js中使用echarts实现数据动态刷新功能
Apr 16 Javascript
vue3.0搭配.net core实现文件上传组件
Oct 29 Javascript
JS数组方法some、every和find的使用详情
Oct 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
虫族 ZERG 概述
2020/03/14 星际争霸
DedeCMS dede_channeltype表字段注释
2010/04/07 PHP
关于session在PHP5的配置文件中的详细设置参数说明
2011/04/20 PHP
PHP在获取指定目录下的目录,在获取的目录下面再创建文件,多平台
2011/08/03 PHP
PHP5常用函数列表(分享)
2013/06/07 PHP
关于Sphinx创建全文检索的索引介绍
2013/06/25 PHP
PHP URL路由类实例
2013/11/12 PHP
PHP使用ffmpeg给视频增加字幕显示的方法
2015/03/12 PHP
PHP判断来访是搜索引擎蜘蛛还是普通用户的代码小结
2015/09/14 PHP
分享php多功能图片处理类
2016/05/15 PHP
仿服务器端脚本方式的JS模板实现方法
2007/04/27 Javascript
jQuery操作select的实例代码
2012/06/14 Javascript
jquery制作弹窗提示窗口代码分享
2014/03/02 Javascript
JQuery中clone方法复制节点
2015/05/18 Javascript
javascript实现设置、获取和删除Cookie的方法
2015/06/01 Javascript
JS获取鼠标选中的文字
2016/08/10 Javascript
js轮播图无缝滚动效果
2017/06/17 Javascript
vue 关闭浏览器窗口的时候,清空localStorage的数据示例
2019/11/06 Javascript
[05:31]DOTA2上海特级锦标赛主赛事第三日RECAP
2016/03/05 DOTA
[49:08]OpTic vs Serenity 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
Python pickle模块用法实例
2015/04/14 Python
浅谈scrapy 的基本命令介绍
2017/06/13 Python
Python3.5实现的罗马数字转换成整数功能示例
2019/02/25 Python
在python image 中安装中文字体的实现方法
2019/08/22 Python
python实现将两个文件夹合并至另一个文件夹(制作数据集)
2020/04/03 Python
查找适用于matplotlib的中文字体名称与实际文件名对应关系的方法
2021/01/05 Python
推荐10个CSS3 制作的创意下拉菜单效果
2014/02/11 HTML / CSS
html5通过canvas实现刮刮卡效果示例分享
2014/01/27 HTML / CSS
贝嫂喜欢的婴儿品牌,个性化的婴儿礼物:My 1st Years
2017/11/19 全球购物
Linux开机引导的步骤是什么
2014/02/26 面试题
环保建议书
2014/03/12 职场文书
二手房买卖协议书
2014/04/10 职场文书
比赛口号大全
2014/06/10 职场文书
党员个人年度总结
2015/02/14 职场文书
写作技巧:如何撰写一份优秀的营销策划书
2019/08/13 职场文书
国庆节到了,利用JS实现一个生成国庆风头像的小工具 详解实现过程
2021/10/05 Javascript