成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

webpack4搭建腳手架_04

JowayYoung / 1877人閱讀

摘要:入門和使用介紹這是的上的基本的介紹本質(zhì)上,是一個現(xiàn)代應(yīng)用程序的靜態(tài)模塊打包器。在處理應(yīng)用程序時,它會在內(nèi)部創(chuàng)建一個依賴圖,用于映射到項(xiàng)目需要的每個模塊,然后將所有這些依賴生成到一個或多個。的文檔新接手的項(xiàng)目,從輪子開始就自己搭建。

webpack4入門和使用 webpack介紹

這是webpak的上的基本的介紹:本質(zhì)上,webpack 是一個現(xiàn)代 JavaScript 應(yīng)用程序的靜態(tài)模塊打包器(static module bundler)。在 webpack 處理應(yīng)用程序時,它會在內(nèi)部創(chuàng)建一個依賴圖(dependency graph),用于映射到項(xiàng)目需要的每個模塊,然后將所有這些依賴生成到一個或多個bundle。
webpack的文檔 https://webpack.docschina.org...
新接手的項(xiàng)目,從輪子開始就自己搭建。網(wǎng)上也找了很久的,也沒找到很合適的輪子,那就自己建一個吧。wewebpack4 也更新了很多東西。

新建項(xiàng)目
mkdir webpack-init
cd webpack-init
npm init

之后就跟著提示把package.json中的信息補(bǔ)充完整就可以了.

新建JS文件

目錄

.
├── ./package.json
├── ./src
│?? └── ./src/index.js
├── ./webpack.config.js
├── ./yarn-error.log
└── ./yarn.lock

其中webpack.config.js 如下

const path = require("path");
const HtmlWebpackPlugin = require("html-webpack-plugin"); //通過 npm 安裝

module.exports = {
    entry: "./src/index.js", //入口文件,src下的index.js
    output: {
        path: path.join(__dirname, "dist"), // 出口目錄,dist文件
        filename: "[name].[hash].js" //這里name就是打包出來的文件名,因?yàn)槭菃稳肟?,就是main,多入口下回分解
    },
    module: {},
    plugin: [],
    devServer: {
        contentBase: path.join(__dirname, "dist"), //靜態(tài)文件根目錄
        port: 8080, // 端口
        host: "localhost",
        overlay: true,
        compress: true // 服務(wù)器返回瀏覽器的時候是否啟動gzip壓縮
    }
};
添加插件 js文件加載
yarn add ]babel-core babel-loader babel-preset-es2015 babel-preset-react babel-preset-stage-0 -D

新建.babelrc 文件

 {
   "presets": [
     "es2015",
     "react",
     "stage-0"
   ],
   "plugins": []
//babel-core 調(diào)用Babel的API進(jìn)行轉(zhuǎn)碼
//babel-loader
//babel-preset-es2015 用于解析 ES6
//babel-preset-react 用于解析 JSX
//babel-preset-stage-0 用于解析 ES7 提案

 }
 /*src文件夾下面的以.js結(jié)尾的文件,要使用babel解析*/
 /*cacheDirectory是用來緩存編譯結(jié)果,下次編譯加速*/
 module: {
     rules: [{
         test: /.js$/,
         use: ["babel-loader?cacheDirectory=true"],
         include: path.join(__dirname, "src")
     }]
 }
css文件加載
yarn add style-loader -D
yarn add  css-loader -D

添加配置:

 rules: {
        test: /.css$/,
        use: ["style-laoder", "css-loader"],
        include: path.join(__dirname, "src"), //限制范圍,提高打包速度
        exclude: /node_modules/
    }
html模板生成
//通過 npm 安裝 webpack.config.js頭部添加
const HtmlWebpackPlugin = require("html-webpack-plugin"); 
//插件添加
plugin: [
        // 通過new一下這個類來使用插件
        new HtmlWebpackPlugin({
            // 用哪個html作為模板
            // 在src目錄下創(chuàng)建一個index.html頁面當(dāng)做模板來用
            template: "./src/index.html",
            hash: true // 會在打包好的bundle.js后面加上hash串
        })
    ]

復(fù)制靜態(tài)資源
yarn add copy-webpack-plugin -D

添加插件配置

new CopyWebpackPlugin([
  {
    from: path.resolve(__dirname, "public/static"),
    to: path.resolve(__dirname, "dist/static"),
    ignore: [".*"]
  }
])
webpack.base.conf.js
// webpack.base.conf.js
const path = require("path");

const APP_PATH = path.resolve(__dirname, "../src");
const DIST_PATH = path.resolve(__dirname, "../dist");
module.exports = {
  entry: {
    app: ["./src/index.js"],
  },
  output: {
    // filename: "js/[name].[hash].js", //使用hash進(jìn)行標(biāo)記,
    filename: "[name].[chunkhash].js",
    chunkFilename: "[name].[chunkhash].js",
    path: DIST_PATH,
  },
  module: {
    rules: [
      {
        test: /.js|jsx$/,
        exclude: /node_modules/,
        use: {
          loader: "babel-loader",
        },
      },
      {
        test: /.scss$/,
        use: [
          {
            loader: "style-loader", // 將 JS 字符串生成為 style 節(jié)點(diǎn)
          },
          {
            loader: "css-loader", // 將 CSS 轉(zhuǎn)化成 CommonJS 模塊
          },
          {
            loader: "sass-loader", // 將 Sass 編譯成 CSS
          },
        ],
      },
      {
        // 使用css配置
        test: /.css$/,
        loader: "style-loader!css-loader",
      },
      {
        // 使用less配置
        test: /.less$/,
        loader: "style-loader!css-loader",
      },
      {
        test: /.(png|jpg|gif)$/,
        use: [
          {
            loader: "url-loader",
            options: {
              limit: 8192,
              name: "images/[hash].[ext]", // 所有圖片在一個目錄
            },
          },
        ],
      },
    ],
  },
};
webpack.dev.conf.js
const path = require("path");
const merge = require("webpack-merge");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const webpack = require("webpack");
const baseWebpackConfig = require("./webpack.base.conf.js");

module.exports = merge(baseWebpackConfig, {
  mode: "development",
  output: {
    filename: "js/[name].[hash].js",
  },
  // 源錯誤檢查
  devtool: "inline-source-map",
  plugins: [
    // 處理html
    new HtmlWebpackPlugin({
      template: "public/index.html",
      inject: "body",
      minify: {
        html5: true,
      },
      hash: false,
    }),
    // 熱更新
    new webpack.HotModuleReplacementPlugin(),
  ],
  // 熱更新
  devServer: {
    port: "3200",
    contentBase: path.join(__dirname, "../public"),
    historyApiFallback: true,
    hot: true, // 開啟
    https: false,
    noInfo: true,
    open: true,
    proxy: {
      // "/": {
      //   target: "http://internal.api.pre.ucloudadmin.com",
      //   changeOrigin: true,
      //   secure: false,
      // },
    },
  },
});
webpack.prod.conf.js 文件
// webpack.prod.conf.js 文件
const CleanWebpackPlugin = require("clean-webpack-plugin");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const BundleAnalyzerPlugin = require("webpack-bundle-analyzer")
  .BundleAnalyzerPlugin;
const CopyWebpackPlugin = require("copy-webpack-plugin");
const merge = require("webpack-merge"); // 合并配置
const webpack = require("webpack");
const baseWebpackConfig = require("./webpack.base.conf");

module.exports = merge(baseWebpackConfig, {
  mode: "production", // mode是webpack4新增的模式
  plugins: [
    new HtmlWebpackPlugin({
      template: "public/index.html",
      title: "Pareto", // 更改HTML的title的內(nèi)容
      favicon: "public/favicon.ico",
      minify: {
        removeComments: true,
        collapseWhitespace: true,
        removeAttributeQuotes: true,
      },
    }),
    new CleanWebpackPlugin(["../dist"], { allowExternal: true }),
    new BundleAnalyzerPlugin(),
    new CopyWebpackPlugin([
      {
        from: "public/index.css",
        to: "../dist",
      },
    ]),
  ],
  optimization: {
    // runtimeChunk: {
    //     name: "manifest"
    // },
    splitChunks: {
      cacheGroups: {
        commons: {
          chunks: "initial",
          minChunks: 2,
          maxInitialRequests: 5,
          minSize: 0,
        },
        vendor: {
          // 將第三方模塊提取出來
          test: /node_modules/,
          chunks: "initial",
          name: "vendor",
          priority: 10, // 優(yōu)先
          enforce: true,
        },
      },
    },
  },
});

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/98517.html

相關(guān)文章

  • webpack4詳細(xì)教程,從無到有搭建react手架(二)

    摘要:相關(guān)鏈接詳細(xì)教程,從無到有搭建腳手架一配置插件,這兩個插件基本上是必配的了介紹每次打包時清理上次打包生成的目錄官網(wǎng)指南關(guān)于這個插件部分內(nèi)容已經(jīng)過時沒有更新,按照官網(wǎng)配置會出錯,所以參考上這個插件文檔來配置,文檔地址生成打 相關(guān)鏈接 webpack4詳細(xì)教程,從無到有搭建react腳手架(一) 配置插件 clean-webpack-plugin、 html-webpack-plugin...

    cuieney 評論0 收藏0
  • webpack4詳細(xì)教程,從無到有搭建react手架(三)

    摘要:相關(guān)鏈接詳細(xì)教程,從無到有搭建腳手架一詳細(xì)教程,從無到有搭建腳手架二安裝配置創(chuàng)建,效果安裝配置創(chuàng)建效果配置模式修改配置現(xiàn)在編譯后的由動態(tài)內(nèi)聯(lián)在中,需要分離到單獨(dú)的文件安裝插 相關(guān)鏈接 webpack4詳細(xì)教程,從無到有搭建react腳手架(一) webpack4詳細(xì)教程,從無到有搭建react腳手架(二) Css 安裝loader yarn add style-loader css...

    Sunxb 評論0 收藏0
  • webpack4詳細(xì)教程,從無到有搭建react手架(一)

    摘要:是一個現(xiàn)代應(yīng)用程序的靜態(tài)模塊打包器,前端模塊化的基礎(chǔ)。作為一個前端工程師切圖仔,非常有必要學(xué)習(xí)。官網(wǎng)的文檔非常的棒,中文文檔也非常給力,可以媲美的文檔。建議先看概念篇章,再看指南,然后看和配置總覽。 webpack 是一個現(xiàn)代 JavaScript 應(yīng)用程序的靜態(tài)模塊打包器,前端模塊化的基礎(chǔ)。作為一個前端工程師(切圖仔),非常有必要學(xué)習(xí)。 showImg(https://segment...

    zhkai 評論0 收藏0
  • webpack4詳細(xì)教程,從無到有搭建react手架(四)

    摘要:相關(guān)鏈接詳細(xì)教程,從無到有搭建腳手架一詳細(xì)教程,從無到有搭建腳手架二詳細(xì)教程,從無到有搭建腳手架三管理打包后目錄結(jié)構(gòu)打包結(jié)構(gòu)如下修改配置通過相對目錄對資源命名前加上目錄名,效果后面的步驟在這里需要安裝一個大型的包,以為例安裝為第三 相關(guān)鏈接 webpack4詳細(xì)教程,從無到有搭建react腳手架(一) webpack4詳細(xì)教程,從無到有搭建react腳手架(二) webpack4詳細(xì)...

    chnmagnus 評論0 收藏0
  • webpack4 系列教程: 前言

    摘要:課程地址全部課程地址立即進(jìn)入課程源碼目錄截至按照知識點(diǎn),目錄分成了個文件夾之后還會持續(xù)更新。個人網(wǎng)站原文鏈接系列教程前言 本文檔已經(jīng)過時,最近內(nèi)容請看:https://godbmw.com/passage/76。一共16節(jié)課程和代碼。謝謝支持。 1. 什么是webpack? 前端目前最主流的javascript打包工具,在它的幫助下,開發(fā)者可以輕松地實(shí)現(xiàn)加密代碼、多平臺兼容。而最重要的...

    DevWiki 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<