admin管理员组文章数量:1356375
A vue file in my project has bee too big. I wanted to seperate its script section into a js file. In js file, I export the Vue object;
export default new Vue({
data: {
search: "",
...
And import it in the Vue file;
<script src="./RecordNameTable.js">
</script>
But this is not working, it gives errors. I can import it as a .vue file which has the classic Vue syntax between <script></script>
tags. But I do not want this. How to solve this problem?
A vue file in my project has bee too big. I wanted to seperate its script section into a js file. In js file, I export the Vue object;
export default new Vue({
data: {
search: "",
...
And import it in the Vue file;
<script src="./RecordNameTable.js">
</script>
But this is not working, it gives errors. I can import it as a .vue file which has the classic Vue syntax between <script></script>
tags. But I do not want this. How to solve this problem?
-
try to replace
export default
withmodule.exports = new Vue({...
and can you share the errors that shows? – Ghyath Darwish Commented Sep 12, 2019 at 11:14 -
Is it a single file ponent with
.vue
extension? – Mahmudur Rahman Commented Sep 12, 2019 at 11:28 - @GhyathDarwish this error thrown when module.exports is used; Uncaught TypeError: Cannot assign to read only property 'exports' of object '#<Object>' – dreyzz Commented Sep 12, 2019 at 11:34
- @PrisonerRaju yes – dreyzz Commented Sep 12, 2019 at 11:34
- You may try to force type="module" on your script tag. Doc: developer.mozilla/en-US/docs/Web/JavaScript/Guide/Modules – Sackey Commented Sep 12, 2019 at 11:35
4 Answers
Reset to default 4You have to export an object from your external script, Not a Vue instance.
Here is a simple solution
App.vue
<template>
<div>
{{ message }}
</div>
</template>
// This will work
<script src="./app.js"></script>
// this will work too
<script>
import App from './app.js';
export default App;
</script>
app.js
export default {
data(){
return {
message: "Hello world"
};
}
}
You solve the problem by dropping the "But I do not want this." attitude and simply use the only available solution at this point:
<script>
import Obj from 'location';
export default Obj;
</script>
For vue 3 using Object Destructuring
<script>
import File_script from "./file_script.js";
export default {...File_script}
</script>
If it's bee too big the correct approach is to break your template down into further ponents, not simply move the problem (and making it worse) by moving the script section to another file. You're approaching this wrong.
本文标签: javascriptHow to separate script section of Vue file to another fileStack Overflow
版权声明:本文标题:javascript - How to separate script section of Vue file to another file? - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743978979a2570993.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论