了解webpack

2021-01-10  本文已影响0人  拾钱运

打包工具还有:webpack,grunt,gulp
webpack功能和扩展性好

webpack 概念

webpack将项目看做一个整体,通过一个给定的主文件,webpack将这个文件开始找到你的项目的所有依赖的文件,使用loader处理他们,最后打包成一个或多个浏览器可以识别的js文件。

webpack是模块打包机
webpack-dev-server 用来创建本地服务器,监听代码修改,并自动刷新修改

devServer:{
  contentBase:'./Src',  //本地服务所加载的页面所在的目录
  historyApiFallback:true,
  inline:true //实时刷新
}

loader

loader的作用
1.实现对不同格式的文件的处理,比如将scss转换成css,或者typescript转化为js
loader是webpack最重要的部分之一,通过使用不同的loader,我们能够调用外部的脚本或者工具,实现对不同格式文件的处理,loader需要在webpack.config.js里面单独用module进行配置

var baseConfig={
  module:{
    rules:[
        {
          test:/\.scss$/,
          use:[
            loader:scss-loader,
            query:'其他配置'
          ],
          exclude:/node_modules/
        }
    ]
}
}

plugins

loader负责的是处理源文件css,jsx,一次性处理一个文件,而plugins并不是直接操作单个文件,他是对整个构建过程中作用

ExtractTextWebpackPlugin:他会将入口中引用css文件,都打包成独立的css文件,而不是嵌在js打包文件中,他的应用如下

var ExtractTextPlugin=require('extract-text-webpack-plugin')
var lessRules={
    use:[
      {loader:'css-loader'},
      {loader:'less-loader'}
    ]
}
var baseConfig={
      module:{
        rules:[
          {test:/\.less$/,use:ExtractTextPlugin.extract(lessRules)}
        ]
      },
    pugins:[
        new ExtractTextPlugin('main.css')
      ]
  }

配置npm run build 打包文件到指定文件夹下

vue2配置
    index: path.resolve(__dirname, '../../../cbs-mobile-sales-restful/src/main/webapp/aaa/index.html'),

    // Paths
    assetsRoot: path.resolve(__dirname, '../../../cbs-mobile-sales-restful/src/main/webapp/aaa'),
    assetsSubDirectory: 'static',
assetsRoot:构建输出目录 也就是构建后的东西都扔这里
assetsSubDirectory:资源子目录 除了index.html,其余的js img css都分在这里
assetsPublicPath:项目目录 一个杠杠 啥意思呢,是根目录的意思
vue3配置
 outputDir: '../../cbs-mobile-sales-restful/src/main/webapp/actuals',
moudule.exports和export 之间有什么区别
前者公开了他只想的对象,后者公开了他指向对象的属性

const car = {
  brand: 'Ford',
  model: 'Fiesta'
}

module.exports = car

//在另一个文件中

const car = require('./car')




另一种方式
const car = {
  brand: 'Ford',
  model: 'Fiesta'
}

exports.car = car
或者
exports.car = {
  brand: 'Ford',
  model: 'Fiesta'
}

另一个文件夹引入
const items = require('./items')
items.car
或者
const car = require('./items').car
上一篇 下一篇

猜你喜欢

热点阅读