繁体   English   中英

由于 lang="ts" 属性,基于 typescript 的 vue 文件缺少源映射

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM