【发布时间】:2020-06-21 09:29:12
【问题描述】:
我是 Vue.js 的新手,正在尝试创建一个使用 jQuery formBuilder 插件的自定义组件。当我将组件文件包含在另一个组件中时,出现错误:
未捕获的 ReferenceError:jQuery 未在 /resources/js/form-builder.min.js 中定义
我创建了一个名为 formBuilder.vue 的自定义组件。下面是组件代码:
<template>
<div class="content">
<formBuilder/>
</div>
</template>
<script>
// import './jquery.min.js';
// import './jquery-ui.min.js';
// import './form-builder.min.js';
export default {
created() {
},
data() {
return {
}
},
mounted() {
jQuery(this.$el).formBuilder();
},
methods: {
}
}
</script>
在resource/js/app.js中的app.js文件中,我称这个vue被其他组件递归使用:
window.Vue = require('vue');
require('./bootstrap');
require('admin-lte');
require('./datatable');
import router from './router';
import Datepicker from 'vuejs-datepicker';
import CKEditor from 'ckeditor4-vue';
import FullCalendar from 'vue-full-calendar';
import 'fullcalendar/dist/fullcalendar.css'
import Vue from 'vue';
import jQuery from 'jquery'
import './form-builder.min.js';
Vue.use(VueRouter)
Vue.use(FullCalendar);
Vue.use(CKEditor)
Vue.component("vue-datepicker", Datepicker);
Vue.component('FormBuilder', require('./components/tools/formBuilder.vue').default);
const app = new Vue({
el: '#app',
router
});
这是我使用 formbuilder 组件的组件文件
<template>
<div class="content-wrapper">
<div class="content-header">
<div class="container-fluid">
<div class="row mb-2">
<div class="col-sm-6">
<h1 class="m-0 text-dark">Questionnaire</h1>
</div>
<div class="col-sm-6"></div>
</div>
</div>
</div>
<div class="content">
<div class="container-fluid">
<div class="row justify-content-center">
<div class="col-md-12">
<div class="card">
<FormBuilder/> <!--- used formbuilder component --->
</div>
</div>
</div>
</div>
</div>
</div>
</template>
<script>
export default {
created() {
},
data() {
return {
}
},
methods: {
}
}
</script>
你们能帮我找出我做错的地方吗?
提前致谢。
【问题讨论】:
-
这能回答你的问题吗? JQuery - $ is not defined
标签: javascript jquery vue.js vuejs2 vue-component