如何在 vuejs webpack cli 项目中包含 jquery?

Posted

技术标签:

【中文标题】如何在 vuejs webpack cli 项目中包含 jquery?【英文标题】:How to include jquery in a vuejs webpack cli project? 【发布时间】:2017-11-13 18:43:48 【问题描述】:

您好,我曾经使用 vuejs cli 生成项目 (https://github.com/vuejs/vue-cli)。 cli 使用 webpack,我在 vue 文件中使用 jquery 时遇到问题。我总是得到一个。

http://eslint.org/docs/rules/no-undef  '$' is not defined

我已尝试编辑我的 webpack.dev.config 以包含提供插件块,如下所示:

var utils = require('./utils')
var webpack = require('webpack')
var config = require('../config')
var merge = require('webpack-merge')
var baseWebpackConfig = require('./webpack.base.conf')
var htmlWebpackPlugin = require('html-webpack-plugin')
var FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin')

// add hot-reload related code to entry chunks
Object.keys(baseWebpackConfig.entry).forEach(function (name) 
  baseWebpackConfig.entry[name] = ['./build/dev-client'].concat(baseWebpackConfig.entry[name])
)

module.exports = merge(baseWebpackConfig, 
  module: 
    rules: utils.styleLoaders( sourceMap: config.dev.cssSourceMap )
  ,
  // cheap-module-eval-source-map is faster for development
  devtool: '#cheap-module-eval-source-map',
  plugins: [
    new webpack.DefinePlugin(
      'process.env': config.dev.env
    ),
    // https://github.com/glenjamin/webpack-hot-middleware#installation--usage
    new webpack.HotModuleReplacementPlugin(),
    new webpack.NoEmitOnErrorsPlugin(),
    // https://github.com/ampedandwired/html-webpack-plugin
    new HtmlWebpackPlugin(
      filename: 'index.html',
      template: 'index.html',
      inject: true
    ),
    new FriendlyErrorsPlugin(),
    new webpack.ProvidePlugin(
      $ : "jquery",
      jQuery : "jquery"
    )
  ]
)

然而,当我尝试使用 jquery 时,我一次又一次地遇到同样的问题。我不反对为此使用cdn,无论我尝试什么,我都无法让这个想法包含jquery。

如果 vue 文件有帮助,我会尝试在脚本块中像这样控制台.log $

<script>
export default 
  name: 'how_can_we_help_you',
  data () 
    return 
      msg: 'Welcome to Your Vue.js App'
    
  

console.log($)
</script>

请帮助我陷入困境,并且一直在尝试解决这个问题。提前致谢。

【问题讨论】:

为什么在 Vue 中需要 jquery?使用 jquery + vue 或 jquery + angular 被认为是一种非常糟糕的做法。无论你在 jquery 中可以实现什么,你都应该能够在 vue 中编写它 @Plankton 不是真的。使用 jquery 可以更轻松地进行一些操作 你可能会觉得这个链接很有趣:vuetips.com/bootstrap @john 通常不会。 jQuery 更加熟悉。使用 jQuery 的真正问题是它通常用于 dom 操作,这也由 Vue 处理,所以如果你不小心,你可能会陷入混乱,这就是为什么它被认为是不好的做法。如果你小心点,没关系。 @craig_h 我知道这一点。但是有 一些部分 jquery 比 vue 处理得更好、更容易。我要说的是,不用通过组件和编写方法来调度事件,您可以简单地使用 1 行 jquery ----假设您不会干扰 vue 的渲染数据。我希望你明白我在这里想说什么 【参考方案1】:

进入 main.js 并执行

window.$ = window.jQuery = require('jquery')

Vue.use(
    install: function(Vue, options)
        Vue.prototype.$jQuery = require('jquery'); // you'll have this.$jQuery anywhere in your vue project
    
)

【讨论】:

在对 Internet 上其他地方的复杂答案感到满意后,事实证明,只需第一个简单的单线即可使其工作。非常好。【参考方案2】:

经过两天的搜索。它的 eslintrc.js

将此添加到以下内容中,它将修复提供插件。

env: 
  browser: true,
  jquery: true
,

【讨论】:

【参考方案3】:

对于不使用 webpack 的人来说,另一种方法是使用expose-loader:

yarn add expose-loader

在你的 main.js 中

import "expose-loader?$!jquery";

【讨论】:

【参考方案4】:

我找到了我的解决方案。我将更改放入 webpack.dev.conf.js 而不是 webpack.dev.config 和 eslintrc.json 而不是 eslintrc.js。

【讨论】:

以上是关于如何在 vuejs webpack cli 项目中包含 jquery?的主要内容,如果未能解决你的问题,请参考以下文章

vue-cli创建项目没有集成webpack相关配置的如何解决

VueJSwindows环境安装vue-cli及webpack并创建VueJS项目

vue-cli Failed to download repo vuejs-templates/webpack连接超时解决办法

VueJS 和 Webpack:构建项目无法访问 ENV var

vuejs:vue-cli webpack 模板无法解析 sass 导入

vuejs实战