前端面试题webpack(1)

1. 对webpack的了解

本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler),将项目当作一个整体,通过一个给定的的主文件,webpack将从这个文件开始找到你的项目的所有依赖文件,使用loaders处理它们,最后打包成一个或多个浏览器可识别的js文件
核心概念:
• 入口(entry)
入口起点(entry point)指示 webpack 应该使用哪个模块,来作为构建其内部依赖图的开始
可以通过在 webpack 配置中配置 entry 属性,来指定一个入口起点(或多个入口起点)

module.exports = {
  entry: './path/to/my/entry/file.js'
};

• 输出(output)
output 属性告诉 webpack 在哪里输出它所创建的 bundles ,以及如何命名这些文件,默认值为 ./dist
• loader
loader 让 webpack 能够去处理那些非 JavaScript 文件(webpack 自身只理解 JavaScript)
• 插件(plugins)
loader 被用于转换某些类型的模块,而插件则可以用于执行范围更广的任务。插件的范围包括,从打包优化和压缩,一直到重新定义环境中的变量
• 模式
通过选择 development 或 production 之中的一个,来设置 mode 参数,你可以启用相应模式下的 webpack 内置的优化

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

2. webpack,里面的webpack.config.js怎么配置

let webpack = require('webpack');

module.exports = {
    entry:'./entry.js',  //入口文件
    
    output:{
        //node.js中__dirname变量获取当前模块文件所在目录的完整绝对路径
        path:__dirname, //输出位置
        filename:'build.js' //输入文件
    },
    
    module:{  
        // 关于模块的加载相关,我们就定义在module.loaders中
        // 这里通过正则表达式去匹配不同后缀的文件名,然后给它们定义不同的加载器。
        // 比如说给less文件定义串联的三个加载器(!用来定义级联关系):

        rules:[
          {
            test:/\.css$/,      //支持正则
            loader:'style-loader!css-loader'
          }
        ]
    },
    
    //配置服务
    devServer:{
        hot:true, //启用热模块替换
        inline:true 
        //此模式支持热模块替换:热模块替换的好处是只替换更新的部分,而不是页面重载.
    },
    
    //其他解决方案配置
    resolve:{ 
        extensions:['','.js','.json','.css','.scss']  
    },
    
    //插件
    plugins:[
        new webpack.BannerPlugin('This file is create by baibai')
    ]

}

3. webpack本地开发怎么解决跨域的

• 下载 webpack-dev-server 插件
• 配置 webpack.config.js 文件

// webpack.config.js

var WebpackDevServer = require("webpack-dev-server");

module.exports = {
    ...
    
    devServer: {
        ...
        port: '8088', //设置端口号
        // 代理设置
        proxy: {
            '/api': {
                target: 'http://localhost:80/index.php', // 目标代理
                pathRewrite: {'^/api' : ''}, // 重写路径
                secure: false, // 是否接受运行在 HTTPS 上
                
            }
        }
    }
}

4. 如何配置多入口文件

配置多个入口文件

entry: {
  home: resolve(__dirname, "src/home/index.js"),
  about: resolve(__dirname, "src/about/index.js")
}

5. webpack与grunt、gulp的不同

三者都是前端构建工具
grunt 和 gulp 是基于任务和流的。找到一个(或一类)文件,对其做一系列链式操作,更新流上的数据, 整条链式操作构成了一个任务,多个任务就构成了整个web的构建流程
webpack 是基于入口的。webpack 会自动地递归解析入口所需要加载的所有资源文件,然后用不同的 Loader 来处理不同的文件,用 Plugin 来扩展 webpack 功能
webpack 与前者最大的不同就是支持代码分割,模块化(AMD,CommonJ,ES2015),全局分析
为什么选择webpack

6. 有哪些常见的Loader?他们是解决什么问题的

• css-loader:加载 CSS,支持模块化、压缩、文件导入等特性
• style-loader:把 CSS 代码注入到 JavaScript 中,通过 DOM 操作去加载 CSS
• slint-loader:通过 SLint 检查 JavaScript 代码
• babel-loader:把 ES6 转换成 ES5
• file-loader:把文件输出到一个文件夹中,在代码中通过相对 URL 去引用输出的文件
• url-loader:和 file-loader 类似,但是能在文件很小的情况下以 base64 的方式把文件内容注入到代码中去

7. 有哪些常见的Plugin?他们是解决什么问题的

• define-plugin:定义环境变量
• commons-chunk-plugin:提取公共代码

猜你喜欢

转载自blog.csdn.net/AyayaOVO/article/details/106965705