Webpack引入jquery及其插件的几种方法

首先给大家分享一个巨牛巨牛的人工智能教程,是我无意中发现的。教程不仅零基础,通俗易懂,而且非常风趣幽默,还时不时有内涵段子,像看小说一样,哈哈~我正在学习中,觉得太牛了,所以分享给大家!点这里可以跳转到教程

                    

1. 直接引入[最佳方案]

直接引入的关键在于输出的配置,这里以var为例,如下:

 output : {      filename : '[name].js',       //  devServer不可配置为绝对路径       //publicPath: "http://localhost:8080/dist/",       publicPath: "/dist/",       path : build,       //  umd包含了对amd、commonjs、var等多种规范的支持       //   关键在于这里         libraryTarget : 'var'     },  //  其他配置略 resolve: {        //extensions: ['', '.js', '.es6', '.vue'],        alias: {            //  也可以不写            jquery: 'jquery/dist/jquery.min.js',          }}
  
  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

这样,在编译代码时,webpack会自动将jquery打进代码,现在就可以引入代码了

// 可以直接引入jqueryimport $ from 'jquery'// 因为是commonjs规范,所以会按顺序加载,引用成功,如果是output为amd,则必须在requirejs中配置shim,否则失败import 'jquery-ui' 
  
  
  • 1
  • 2
  • 3
  • 4

2. ProvidePlugin[难以引入插件]

在webpack中添加插件ProvidePlugin
  
  
  • 1
plugins: [    new webpack.ProvidePlugin({      $: "jquery",      jQuery: "jquery"    }),  ]//  $函数会自动添加到当前模块的上下文,无需显示声明
  
  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
问题是依旧没有全局的$函数,所以导入插件依旧会失败,并且如果有eslint这样的preLoads,调用语句也难以通过语法校验(因为没有声明$就直接使用),仅这一点,对于我这样的代码处女座就难以接受。
  
  
  • 1

3. expose-loader[推荐使用]

不需要任何其他的插件配合,只要将下面的代码添加到所有的loader之前
  
  
  • 1
 {    test: require.resolve('jquery'),    loader: 'expose?jQuery!expose?$' }
  
  
  • 1
  • 2
  • 3
  • 4
引用时改为如下方式
  
  
  • 1
import $ from 'expose?$!jquery'import 'jquery-ui' //插件可用   
  
  
  • 1
  • 2
 imports-loader、script-loader同样可达到此效果,配置与功能都非常相似,在此不一一说明。
  
  
  • 1

4. 包装jquery[推荐使用]

此方法只依赖于自己,完全不需要任何其他插件与加载器,创建jquery的包装对象jquery-vendor.js
  
  
  • 1
import $ from 'jquery'window.$ = $window.jQuery = $export default $
  
  
  • 1
  • 2
  • 3
  • 4
以后引用jquery时指向jquery-vendor.js
  
  
  • 1
import $ from '../assets/jquery-vendor.js'import 'jquery-ui'//  此时UI的方法全部可用,如果需要引用bootstrap,可参照此方法
  
  
  • 1
  • 2
  • 3
  • 4
为了调用方便,可在webpack配置文件中创建jquery-vendor.js的别名
  
  
  • 1
alias: {    jquery        : 'src/assets/jquery-vendor.js' //    将其指向jquery-vendor.js所在位置}   
  
  
  • 1
  • 2
  • 3
  • 4

可参考我的项目中的配置文件。

           

浏览人工智能教程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值