Vue3+ElementPlus+TypeScript 开发常见问题/警告/错误 (持续补充......)

el-popconfirm 事件冒泡

// 在confirm添加stop无效,需要在按钮上添加 @click.native.stop
<el-popconfirm :title="tip" @confirm.stop="onConfirm">
    <template #reference>
      <el-button size="small" type="danger" link @click.native.stop>
        删除
      </el-button>
    </template>
  </el-popconfirm>

TS2339: Property ‘id’ does not exist on type ‘{}’

// 原代码
const xxx = (row:object) => {
  const {id} = row
}
// 修改后
const xxx = (row: { id: string }) => {
  const {id} = row
}

TS2322: Type ‘HTMLElement | null’ is not assignable to type
‘HTMLElement | undefined’. Type ‘null’ is not assignable to type
‘HTMLElement | undefined’

// 原代码
const dom = document.getElementById('container')
// 修改后
const dom: (HTMLElement | null) = document.getElementById('container')

Vue3+TS ref定义类型

// 定义
const screenWidth = ref<number>(window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth)

ts类型嵌套

  interface node {
    id: string,
    x: number,
    y: number,
    width: number,
    height: number,
    label: string
  }

  interface edges {
    source: string,
    target: string
  }

  interface nodeInfo {
    nodes: node[],
    edges: edges
  }

ts2691:TypeScript 中 An import path cannot end with a ‘.ts’ extension

  要解决该错误,需要在导入文件时删除 .ts 扩展名。
  import {mousewheel} from './commonConfig.ts';
  // 修改后
  import {mousewheel} from './commonConfig';

1208 Cannot compile namespaces when the ‘–isolatedModules’ flag is provided

  修改 tsconfig.json
 "isolatedModules": false,
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值