Vue watch TypeScript错误TS2769:没有重载匹配这个调用

Posted

技术标签:

【中文标题】Vue watch TypeScript错误TS2769:没有重载匹配这个调用【英文标题】:Vue watch TypeScript error TS2769: No overload matches this call 【发布时间】:2020-08-22 19:23:06 【问题描述】:

考虑以下代码:

export default defineComponent(
  setup() 
    const miniState = ref(true)

    const setMiniState = (state: boolean, screenWidth: number) => 
      if (screenWidth > 1023) 
        miniState.value = false
       else if (state !== void 0) 
        miniState.value = state === true
      
      else 
        miniState.value = true
      
    

    watch('$q.screen.width', (width) => setMiniState(true, width))

    return  miniState, setMiniState 
  
)

TypeScript 抛出此错误:

TS2769:没有与此调用匹配的重载。 重载 1 of 3, '(来源: SimpleEffect, options?: Pick, "deep" | “冲洗”> | undefined): StopHandle',给出以下错误。 '"$q.screen.width"' 类型的参数不能分配给 'SimpleEffect' 类型的参数。

Overload 2 of 3, '(source: WatcherSource, cb: WatcherCallBack, options?Partial | undefined): StopHandle',给出了以下错误。 '"$q.screen.width"' 类型的参数不能分配给 'WatcherSource' 类型的参数。

重载 3 of 3, '(sources: WatcherSource[], cb: (newValues: unknown[], oldValues: unknown[], onCleanup: CleanupRegistrator) => any, options?: Partial | undefined): StopHandle',给出了以下错误。 '"$q.screen.width"' 类型的参数不能分配给 'WatcherSource[]' 类型的参数。

这是针对以下代码行的:

watch('$q.screen.width', (width) => setMiniState(true, width))

就目前而言,我将string 交给watch 函数而不是WatcherSource<any>。我尝试了以下方法,但都失败了:

watch('$q.screen.width' as WatcherSource, (width) => setMiniState(true, width)) // fails

watch(('$q.screen.width' as WatcherSource ), (width) => setMiniState(true, width)) // fails

解决这个问题的正确方法是什么?

【问题讨论】:

【参考方案1】:

这是definition of watch and WatcherSource

function watch<T>(
  source: WatcherSource<T>,
  callback: (
    value: T,
    oldValue: T,
    onInvalidate: InvalidateCbRegistrator
  ) => void,
  options?: WatchOptions
): StopHandle

type WatcherSource<T> = Ref<T> | (() => T)

据此,您应该传递 ref 或回调。

watch(() => $q.screen.width, (width) => setMiniState(true, width))

【讨论】:

嗯...如果我使用您的建议 TS 抱怨它找不到 $q 并且当我在它周围加上引号作为字符串时没有 TS 错误但不会触发手表回调 如Quasar docs 中所述,由import Screen from 'quasar' 修复该部分,然后像watch(() =&gt; Screen.width, (width) =&gt; setMiniState(true, +width)) 一样使用它

以上是关于Vue watch TypeScript错误TS2769:没有重载匹配这个调用的主要内容,如果未能解决你的问题,请参考以下文章

Webpack 在编译 typescript 代码失败时会导致 gulp watch 崩溃

Vue+TypeScript项目实践(一)

[Vue + TS] Create your own Decorators in Vue with TypeScript

VSCode 推荐使用的插件大全汇总,完美解决问题

VSCode 推荐使用的插件大全汇总,完美解决问题!

VsCode实用插件推荐,让你的开发效率火力全开