Can anyone tell me why typescript is yelling at me with the following error?
error TS7006: Parameter 'el' implicitly has type 'any'. ref="(el) => saveRef(index, el)"
. I'm pretty sure the correct type is set in the saveRef
function.
<script lang="ts" setup> import FormComponent from '@/components/FormComponent.vue' const formRefs = ref< ComponentPublicInstance<typeof FormComponent>[] >([]) function saveRef( index: number, el: ComponentPublicInstance<typeof FormComponent> ) { formRefs.value[index] = el } onBeforeUpdate(() => { formRefs.value = [] }) </script> <template> <div v-for="(component, index) in components" :key="index"> <form-component :ref="(el) => saveRef(index, el)" :component="component" :index="index" /> </div> </template>
It is generally not a good practice to keep redundant JS in templates. The correct solution is to define typed reference handling functions in the component script. Since it should be parameterized, it can be a higher-order function:
and use it as
:ref="saveRef(index)"
.