![](/img/trans.png)
[英]Nuxt Vue Typescript global plugins unavailable inside script lang ts
[英]Sourcemap missing for typescript based vue file due to lang="ts" attribute
我遇到了我想将我的 vue 文件从 JS 切换到 Typescript 的问题。
它们看起来像这样(非常标准)
<template>
...
</template>
<script>
...
</script>
并将它们与 typescript 一起使用我读到我需要将脚本标签调整为<script lang="ts">
。 这很好用,代码很高兴通过 webpack 构建/转换,我可以启动我的应用程序。 唯一的问题是,一旦我将lang="ts"
放入脚本标记中,Chrome 就不再以调试模式显示这些文件,因此似乎缺少它们的源映射信息(尽管我对源映射不太了解)。 所以我想知道如何正确获取源映射以及在 Chrome 开发人员模式下显示的文件,因为显然我将需要它再次进行调试。 给出了所有其他文件的源映射,并且这些文件在 Chrome 中以 dev 模式显示(例如对于 plain.ts 文件)以及尚未基于 TS 的 vue 文件,因此没有lang="ts"
属性。
这是我的 webpack 提取 ts 和 vue 文件
devtool: 'inline-source-map',
module: {
rules: [
{ test: /\.vue$/,
loader: 'vue-loader'
},
{ test: /\.ts$/,
exclude: /node_modules|vue\/src/,
loader: "ts-loader",
options: {
appendTsSuffixTo: [/\.vue$/]
}
}
...
]
},
resolve: {
alias: {
'vue$': 'vue/dist/vue.esm.js'
},
extensions: ['*', '.js', '.vue', '.json', '.ts']
},
以及我的源地图和其他一些可能相关的 tsc 设置
"sourceMap": true,
"strict": true,
"alwaysStrict": true,
"moduleResolution": "node",
"allowSyntheticDefaultImports": true,
"esModuleInterop": true,
/* Source Map Options */
// "sourceRoot": "";
//"mapRoot": "",
//"inlineSourceMap": true,
// "inlineSources": true
我发现使用devtool = 'cheap-module-eval-source'
它可以工作,但是 .vue 文件的目录没有显示并且文件结尾有点奇怪,但它可以工作。 但我不认为这是一个很好的解决方案。 所以如果某人有更好的选择,请告诉我。 然而我面临的下一个问题是 Sonarqube 不接受lang="ts"
因为他们还没有实现它(这是一个功能请求)。
所以最终对我有用的解决方案不是 use.vue 文件,而是使用基于 class 的 sfc 组件,如https://v2.vuejs.org/v2/guide/typescript.html#Class-Style-Vue-中所述组件与 vscode 插件一起突出显示内联 html 代码。 通过这种方式,我得到了工作 TS,工作源映射进行调试,工作 Sonarqube,工作语法突出显示,工作,linting。 我个人的印象是,虽然vue.js很棒,但如果你离开人迹罕至的地方,周围的环境仍然有相当大的差距。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.