Слияние кода завершено, страница обновится автоматически
<template>
<component :is="type" v-bind="linkProps">
<slot />
</component>
</template>
<script lang="ts" setup>
/**
* @description 兼容第三方页面的跳转
*/
import { isExternal } from '@/utils/validate'
interface Props {
to: string | Record<string, string>
replace?: boolean
}
const props = defineProps<Props>()
const isExternalLink = computed(() => {
return typeof props.to !== 'object' && isExternal(props.to)
})
const type = computed(() => {
if (isExternalLink.value) {
return 'a'
}
return 'router-link'
})
const linkProps = computed(() => {
if (isExternalLink.value) {
return {
href: props.to,
target: '_blank'
}
}
return props
})
</script>
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Опубликовать ( 0 )