nuxt+tsx项目 class报错

本文解决了一个Nuxt结合TSX项目中关于class名称声明的问题。TSX基于React封装,使用className声明类名,而在Vue中应使用class。文章提供了修改底层jsx属性定义的解决方案。

nuxt+tsx项目 class报错

原因
tsx是基于react封装的语法格式,类名使用className声明的,而不存在class;但是在vue中是不存在className的,所以是不可以用className的

解决方案:
修改react 底层jsx 属性定义

interface HTMLAttributes<T> extends AriaAttributes, DOMAttributes<T> {
          // React-specific Attributes
          defaultChecked?: boolean;
          defaultValue?: string | string[];
          suppressContentEditableWarning?: boolean;
          suppressHydrationWarning?: boolean;
          class?: string;  // 添加次class属性名即可解决此问题
ERROR in src/modules/data-map/data-table/assets-table-detail/blood/views/g6-blood-table.vue:37:14 TS2339: Property '$axios' does not exist on type 'CombinedVueInstance<Vue, object, object, object, Record<never, any>>'. 35 | if (isInit) { 36 | request = () => > 37 | vm.$axios | ^^^^^^ 38 | .$get(tableLineageBlood(tableId), { 39 | params: { 40 | upstreamLevel: 1, ERROR in src/modules/data-map/data-table/assets-table-detail/blood/views/g6-blood-table.vue:44:19 TS7006: Parameter 'res' implicitly has an 'any' type. 42 | }, 43 | }) > 44 | .then(res => res.payload) | ^^^ 45 | } else { 46 | request = () => 47 | vm.$axios ERROR in src/modules/data-map/data-table/assets-table-detail/blood/views/g6-blood-table.vue:47:14 TS2339: Property '$axios' does not exist on type 'CombinedVueInstance<Vue, object, object, object, Record<never, any>>'. 45 | } else { 46 | request = () => > 47 | vm.$axios | ^^^^^^ 48 | .$get(lineageBlood, { 49 | params: { 50 | nodeId: data.nodeId, ERROR in src/modules/data-map/data-table/assets-table-detail/blood/views/g6-blood-table.vue:55:19 TS7006: Parameter 'res' implicitly has an 'any' type. 53 | }, 54 | }) > 55 | .then(res => res.payload) | ^^^ 56 | } 57 | return request().then((payload: any) => { 58 | return { ERROR in src/modules/data-map/data-table/assets-table-detail/blood/views/g6-blood-table.vue:112:22 TS2339: Property '$router' does not exist on type 'CombinedVueInstance<Vue, object, object, object, Record<never, any>>'. 110 | value: data.dataCollectSuccess 111 | ? `<a class="tooltip-value primary" href="${ > 112 | vm.$router.resolve(`/data-map/data-table/${data.tableId}`).href | ^^^^^^^ 113 | }"> ${data.tableName} </a>` 114 | : data.tableName, 115 | }, FATAL Nuxt build error 09:02:49 at WebpackBundler.webpackCompile (node_modules/@nuxt/webpack/dist/webpack.js:1888:21) at async WebpackBundler.build (node_modules/@nuxt/webpack/dist/webpack.js:1853:5) at async Builder.build (node_modules/@nuxt/builder/dist/builder.js:249:5) at async ensureBuild (node_modules/@nuxt/cli/dist/cli-generate.js:117:3) at async Object.run (node_modules/@nuxt/cli/dist/cli-generate.js:234:7) at async NuxtCommand.run (node_modules/@nuxt/cli/dist/cli-index.js:356:7) ╭─────────────────────────────╮ │ │ │ ✖ Nuxt Fatal Error │ │ │ │ Error: Nuxt build error │ │ │ ╰─────────────────────────────╯
08-15
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值