如何在 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