概述

在项目中不可避免的会用到jquery等第三方库,来看看有什么问题,怎么解决。

遇到的问题

一般情况下,直接require第三方库,比如jquery,然后webpack会自动把第三方库打包进bundle.js里面去,这样就造成了三个问题:

  1. bundle.js的文件会非常大
  2. 每次更新bundle.js的时候根本没有更新第三方库,但是用户仍然要下载包含所有第三方库的bundle.js,不利于缓存
  3. 更新第三方库的时候很麻烦,又要重新下bundle.js。(虽然这种情况很少)

理想的解决方案

我理想的解决方案是:

  1. 打包前把所有第三方库都放在一个静态文件夹里面。
  2. 打包的时候这个静态文件夹里面的内容不打包进bundle.js。
  3. 打包的时候把这个静态文件夹里面的内容全部扔在打包文件夹里面的一个static文件夹里面。
  4. 打包后在html文件的script标签里面引入这些第三方库。

现实很骨感

我现在也没有时间按照我的方案自己学习并且写一个打包插件,所以只能用现有的解决方案。网上主要的解决方案包括以下几种,具体可自行上网搜索。

  1. 用resolve的alias属性给第三方库起别名来引用。(只解决了全局引用问题,没有解决上面的任何一个问题)
  2. ProvidePlugin插件。(可能存在全局引用问题,并且eslint会不生效,并且没有解决上面的任何一个问题)
  3. 使用expose-loader。(和方案1一样,只解决了全局引用问题,没有解决上面的任何一个问题)
  4. 使用CommonsChunkPlugin插件,把引用次数多的第三方库打包进vendor.js里面去(解决了问题1,没有解决问题12)
  5. externals属性,设置哪些库不打包,还是可以require,只是不打包而已。(可行)

实际用到的方案

最后我只能选择用方案5:利用externals属性。虽然和我的理想解决方案有点出入,但是问题不大。下面来看看具体怎么操作。

(1)修改webpack.config.js,加入externals属性。意思是jquery不打包,并且给它设置一个全局变量,叫做jQuery,在任何地方都可以用jQuery访问jquery库。

//简写
module.exports = {
externals: {
jquery: 'jQuery'
}
}

(2)虽然我们把jQuery设置为全局变量,但是为了保险,我们在引用jquery库的时候,还是用require。把下面语句加入到使用jquery的js文件里面去。

var $ = require('jquery');

(3)由于不打包jquery,所以需要在html的head标签里面加入引入jquery的script标签。建议用网上免费的开源cdn。(搜jquery cdn即可)

<script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.js"></script>

仿B站项目(4)webpack打包第三方库jQuery的更多相关文章

  1. 仿B站项目——(1)计划,前端工程

    计划 现打算: 计划用webpack打包 + 模板语言 + jquery + jquery ui + bootstrap做一个仿B站的静态网站. 网站兼容手机浏览器端. 部分模块打算仿照SPA用js加 ...

  2. Vue老项目支持Webpack打包

    1.老的vue项目支持webpack打包 最近在学习Vue.js.版本是2.6,webpack的版本也相对较老,是2.1.0版本.项目脚手架只配置了npm run dev和npm run build. ...

  3. vue项目通过webpack打包生成的dist文件放到express环境里运行(vue+webpack+express)

    1.首先需要的原料肯定是vue打包生成的dist文件 在vue项目目录下运行:npm run build,等待运行结束,会在项目目录下生成一个dist文件夹,里面会生成一些文件(如下图示) 小的项目文 ...

  4. vue项目之webpack打包静态资源路径不准确

    摘自:https://blog.csdn.net/viewyu12345/article/details/83187815 问题 将打包好的项目部署到服务器,发现报错说图片找不到. 静态资源如js访问 ...

  5. 【vue】饿了么项目-使用webpack打包项目

    1.vue cli给我们提供了npm run build命令打包项目,在packa.json文件中scripts对象中有build属性,当我们执行npm run build时,就执行build对应的& ...

  6. webpack分离第三方库(CommonsChunkPlugin并不是分离第三方库的好办法DllPlugin科学利用浏览器缓存)

    webpack算是个磨人的小妖精了.之前一直站在glup阵营,使用browserify打包,发现webpack已经火到爆炸,深怕被社区遗落,赶紧拿起来把玩一下.本来只想玩一下的.尝试打包了以后,就想启 ...

  7. vue-cli、webpack提取第三方库-----DllPlugin、DllReferencePlugin

    需要安装的插件有 extract-text-webpack-plugin assets-webpack-plugin clean-webpack-plugin npm install extract- ...

  8. webpack 的第三方库分离并持久化缓存

    我们常常需要在浏览器缓存一些稳定的资源,如第三方库等.要达到这个目标,只需要两步: 1.提取出“稳定的资源”: 2.提供稳定的文件hash . 处理后的出的文件就像这样子: app.1w3ad4q4. ...

  9. mac下的应用程序发布 及 打包(Python写的脚本,可打包第三方库)

    其实这个问题在网上能搜到大把的解决方案.大家的统一答案都是 otool -L yourapp.app/Contents/MacOS/yourapp 根据输出信息在运行 install_name_too ...

随机推荐

  1. 安装SourceTree工具,无需注册就可以正常使用SourceTree

    1. 下载SourceTree安装包 2. 双击安装包进行安装,默认会直接安装在系统盘,此时桌面就会SourceTree的快捷键 3. 双击打开桌面的SourceTree,就会提示让你安装授权,那么接 ...

  2. 针对piix4_smbus ****host smbus controller not enabled的解决方法

    SMBus 目录 SMBus与I2C的差别 SMBus 是 System Management Bus 的缩写,是1995年由Intel提出的,应用于移动PC和桌面PC系统中的低速率通讯.它主要是希望 ...

  3. 【转】Appium 优化版

    Appium 开源分享优化版 之前分享过PageObject+Python+Appium 本版本是对上次版本较大改版,主要解决了: 失败重连一次(默认一次)可配置多次 基于appium1.7.1 ui ...

  4. 导出word文档 通过DocX组件

    根据DocX官方描述如下: In the application development process, it uses COM libraries and requires MS Word or ...

  5. React createRef:引用

    一 代码 import React, { Component } from 'react'; class Box extends Component { render() { return <b ...

  6. flutter 自己整理

    2018-05 资料 常见问题解决处 https://flutter.io/flutter-for-android/ 起步 api widget https://flutter.io/docs/ 其他 ...

  7. 加NONCLUSTERED INDEX索引,在ON了之后还要INCLUDE

    之前加了索引,但效果不大 SET STATISTICS TIME ON --执行时间 SET STATISTICS IO ON --IO读取 DBCC DROPCLEANBUFFERS --清除缓冲区 ...

  8. python的基本用法(一)

    1.什么变量,什么是数据类型? 变量就是用来存放东西的, 数据类型:字符串str,整数int,浮点数(小数)float type()函数用来检验数据格式的类型 2.什么是for循环,什么是while循 ...

  9. Java代码获取spring 容器的bean几种方式

    一.目的 写了一个项目,多个module,然后想在A模块中实现固定的config注入,当B模块引用A时候,能够直接填写相对应的配置信息就行了.但是遇到一个问题,B引用A时候,A的配置信息总是填充不了, ...

  10. latex相关概念

    关于Latex,收到网友的鼓励,决定好好整理下相关的信息. 在初次使用相关的程序时,遇到很多迷惑的概念,下面这篇帖子汇总得很详细. 关于latex各种概念与理解 帖子中提到了三个概念,引擎,宏集(即下 ...