我正在CodeMirror
我的应用程序中实现一个文本区域Nuxtjs/Vuejs
。我想textarea
按照XML
.
有时CodeMirror
效果很好,但有时当我重新加载页面时出现错误:
Test.vue
33:18 error 'CodeMirror' is not defined no-under
所以最初它工作得很好但是当我尝试对项目中的任何文件进行一些更改并且当Nuxtjs/Vuejs
服务器再次重新加载以合并新的更改时,我得到了错误error 'CodeMirror' is not defined
我不明白为什么有时会出现错误,而其他时候却没有。由于我已经添加了所需的 CDN 并完成了各种答案和文章中提到的步骤,我希望它根本不会抛出错误。有人可以帮我解决这个问题吗?
后续步骤:
- 将 CDN 添加到我的
nuxt-config.js
::Scripts
script: [
{
src:"text/javascript",
src:"https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.32.0/codemirror.min.js"
},
{
src:"text/javascript",
src:"https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.32.0/mode/xml/xml.min.js"
}
],
CSS
:
{
rel: "stylesheet",
href:"https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.63.1/codemirror.min.css"
}
以下是我的Test.vue
:
<template>
<div>
<div class="row">
<div class="col-md-5">
<div class="row">
<div class="col-md-12">
<textarea
id="test"
v-model="xmlInput"
class="form-control"
placeholder="XML Document"
spellcheck="false"
data-gramm="false"
@input="convertToJSON()"
/>
</div>
</div>
</div>
</div>
</div>
</template>
<script>
export default {
data () {
return {
xmlInput: ''
}
},
methods: {
convertToJSON () {
console.log('ONE')
const cm = CodeMirror.fromTextArea(document.getElementById('test'), {
mode: 'application/xml',
lineNumbers: true,
matchBrackets: true,
styleActiveLine: true,
lineWrapping: true,
tabSize: 2,
value: 'console.log("Hello, World");'
})
cm.setSize(500, 500)
}
}
}
</script>
<style scoped>
textarea {
height: 78vh;
white-space: nowrap;
resize: both;
}
::-webkit-input-placeholder {
color: #f1948a;
text-align: center;
}
</style>
有人可以帮我解决这个问题吗?我在这里做错了什么?任何建议将不胜感激。提前致谢。
用于重新创建问题的沙箱: https ://codesandbox.io/s/boring-water-g14zd?file=/pages/index.vue