概述

在项目中不可避免的会用到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. JUC详解

    一.Java多线程 -- JUC包源码分析1 -- CAS/乐观锁 乐观锁其实就是不加锁,用CAS + 循环重试,实现多个线程/多个客户端,并发修改数据的问题 使用AtomicStampedRefer ...

  2. 保存xml报错 'UTF_8' is not a supported encoding name

    ArgumentException: 'UTF_8' is not a supported encoding name. For information on defining a custom en ...

  3. gitlab 502

    经过一个下午的查找终于发现了错误,原来是在服务器上还开启了一个tomcat服务,占用了8080端口,使GitLab的unicorn服务不能开启. 最后在/etc/gitlab/gitlab.rb 中做 ...

  4. 20175314 《Java程序设计》第五周学习总结

    20175314 <Java程序设计>第五周学习总结 教材学习内容总结 public接口可以被任意一个类实现,友好接口可被同一个包里的接口实现. Java不支持多重继承,即一个类只能有一个 ...

  5. 图论最短路径算法总结(Bellman-Ford + SPFA + DAGSP + Dijkstra + Floyd-Warshall)

    这里感谢百度文库,百度百科,维基百科,还有算法导论的作者以及他的小伙伴们...... 最短路是现实生活中很常见的一个问题,之前练习了很多BFS的题目,BFS可以暴力解决很多最短路的问题,但是他有一定的 ...

  6. 堆优化dij

    #include<iostream> #include<cstdio> #include<queue> using namespace std; ],head[], ...

  7. vue获取后台图片验证码,并点击刷新验证码

    <--url为需要访问的接口地址--> <span style="display: inline-block;width: 130px;height: 53px;borde ...

  8. swift hidesBottomBarWhenPushed 设置界面

    方法一(推荐):一级界面push的时候设置,子页面无需设置 let vc = JYMyCommissionController() vc.hidesBottomBarWhenPushed = true ...

  9. Python开发——函数【Python内建函数】

  10. 201621123002《JAVA程序设计》第三章学习总结

    1. 本周学习总结 1.1 写出你认为本周学习中比较重要的知识点关键词,如类.对象.封装等 关键词:类 对象 封装 构造函数 this,static,final 1.2 用思维导图或者Onenote或 ...