十月还能种植毛桃吗?

小说:十月还能种植毛桃吗?作者:安辛文宗更新时间:2019-04-19字数:33733

李庆安用木棍一指盐港问道:“我们最关心的是盐港码头,可以停得下五千石的海船吗?”

15公分紫薇市场什么价格?

沈静的这栋房子是她贷款买的,在33层,两室一厅,但面积却有一百多平,客厅很大,看上去很宽敞舒适。
悟空不答,默默哭了一阵,觉得心中好受了许多,问道:“这便是我们神猿的命,对不对?”

事实上红豆刚才第一次咬不到自己的手,在红豆支持不住的时候刘皓也会弄出点东西来给红豆咬住的,只是他没想到红豆居然会做出这么出人意料的举动居然咬住自己的嘴巴,真是够丢人的啊。

接触webpack是好久之前的事情了,最近看了下webpack没想到都到4了。

webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler).

会创建1个依赖关系图(dependency graph),包含所有依赖的模块,然后将模块打包成1个或多个bundle.

webpack4 仍然支持高度可配,但完全可以不用配置文件了(基于mode)。

核心配置:

  • 入口(entry):
  • 输出(output):
  • loader:
  • 插件(plugins):

基本特性

Entry

入口起点(entry point)指示 webpack 应该使用哪个模块,来作为构建其内部依赖图的开始。

可以通过在 webpack 配置中配置 entry 属性,来指定一个入口起点(或多个入口起点)。默认值为 ./src/index.js

webpack.config.js

module.exports = {
    entry: {
        main: "./src/index.js"
    },
};

Output

output 属性告诉 webpack 在哪里输出它所创建的 bundles,以及如何命名这些文件,默认值为./dist/[name].js

webpack.config.js

const path = require("path");

module.exports = {
  entry: "./src/index.js",
  output: {
    path: path.resolve(__dirname, "dist"),
    filename: "[name].js"
  }
};

Loader

loader 让 webpack 能够去处理那些非 JavaScript 文件(webpack 自身只理解 JavaScript)。

loaders 有2个核心参数:

  1. test 属性,用于标识出需要转换的某个或某些文件。
  2. use 属性,表示进行转换时,应该使用哪个 loader。
const path = require("path");

const config = {
  output: {
    filename: "bundle.js"
  },
  module: {
    rules: [
      { test: /.txt$/, use: "raw-loader" }
    ]
  }
};

module.exports = config;

Plugins

插件的范围包括,从打包优化和压缩,一直到重新定义环境中的变量。插件接口功能极其强大,可以用来处理各种各样的任务。

webpack.config.js

const HtmlWebpackPlugin = require("html-webpack-plugin"); // 通过 npm 安装
const webpack = require("webpack"); // 用于访问内置插件

const config = {
  module: {
    rules: [
      { test: /.txt$/, use: "raw-loader" }
    ]
  },
  plugins: [
    new webpack.optimize.UglifyJsPlugin(),
    new HtmlWebpackPlugin({template: "./src/index.html"})
  ]
};

module.exports = config;

Mode

通过选择 development 或 production 之中的一个,来设置 mode 参数

webpack.config.js

module.exports = {
  mode: "production"
};

mode.js

// webpack.development.config.js
module.exports = {
+ mode: "development"
- plugins: [
-   new webpack.NamedModulesPlugin(),
-   new webpack.DefinePlugin({ "process.env.NODE_ENV": JSON.stringify("development") }),
- ]
}
// webpack.production.config.js
module.exports = {
+  mode: "production",
-  plugins: [
-    new UglifyJsPlugin(/* ... */),
-    new webpack.DefinePlugin({ "process.env.NODE_ENV": JSON.stringify("production") }),
-    new webpack.optimize.ModuleConcatenationPlugin(),
-    new webpack.NoEmitOnErrorsPlugin()
-  ]
}

常用插件

HtmlWebpackPlugin:

Options

const HtmlWebpackPlugin = require("html-webpack-plugin");

new HtmlWebpackPlugin({ template: "src/index.html", minify: true, hash: true })

CleanWebpackPlugin:

const CleanWebpackPlugin = require("clean-webpack-plugin");

new CleanWebpackPlugin(["dist"])

MiniCssExtractPlugin(ExtractTextPlugin):

new MiniCssExtractPlugin({ filename: "[name].css",chunkFilename: "[id].css" })

module: {
    rules: [{
        test: /.css$/,
        use: [
            MiniCssExtractPlugin.loader,
            "css-loader"
        ]}
    ]
}

SplitChunksPlugin:

module.exports = {
    mode: "development",
    entry: {
        main: "./src/index.js",
        vendors: "lodash"
    },
    optimization: {
        splitChunks: {
            cacheGroups: {
                vendors: {
                    test: /[\/]node_modules[\/]/,
                    name: "vendors",
                    chunks: "initial"
                }
            }
        }
    }
}

配置示例

const CleanWebpackPlugin = require("clean-webpack-plugin");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const MiniCssExtractPlugin = require("mini-css-extract-plugin");

const path = require("path");

module.exports = {
    mode: "development",
    entry: {
        main: "./src/index.js",
    },
    devtool: "inline-source-map",
    devServer: {
        contentBase: "./dist"
    },
    output: {
        path: path.resolve(__dirname, "dist"),
        filename: "[name].js",
    },
    module: {
        rules: [{
            test: /.css$/,
            use: [
                MiniCssExtractPlugin.loader,
                "css-loader"
            ]
        }, {
            test: /.(js|jsx)$/,
            loader: "babel-loader",
            options: {
                presets: ["react"]
            },
            exclude: /node_modules/
        }]
    },
    plugins: [
        new CleanWebpackPlugin(["dist"]),
        new HtmlWebpackPlugin({ template: "src/index.html", minify: true, hash: true }),
        new MiniCssExtractPlugin({ filename: "[name].css", chunkFilename: "[id].css" })
    ],
    externals: {
        lodash: "_",
        react: "React",
        "react-dom": "ReactDOM"
    },
    optimization: {
        splitChunks: {
            cacheGroups: {
                common: {
                    test: /[\/]node_modules[\/]/,
                    name: "common",
                    chunks: "initial"
                }
            }
        }
    }
};

编辑:石龙

发布:2019-04-19 21:55:35

当前文章:http://emigration.net.cn/play/k58hlqs1fa.html

米径16公分金丝柳什么价格能买到? 四季常绿的金边麦冬草厂家直销 花棚廊架专用,100万棵爬藤多花蔷薇上市出售了 红王子锦带别名叫什么? 大杯金森女贞多少钱一棵? 内蒙古有种植紫叶李的基地吗? 红三叶种子种植后几天能发芽? 怎样种植皇竹草种子最好?

74826 19639 12758 56867 54657 90309 84875 39512 69847 88689 58339 92129 52587 64924 99691 78072 89463 97650 50028 60574

我要说两句: (0人参与)

发布