【发布时间】: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 的渲染数据。我希望你明白我在这里想说什么
标签: javascript jquery webpack vue.js