We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
The current youtube placeholder url https://i.ytimg.com/vi_webp/${props.videoId}/sddefault.webp cannot show some videos.
https://i.ytimg.com/vi_webp/${props.videoId}/sddefault.webp
vi_webp
https://i.ytimg.com/vi_webp/mJ8tq8AnNis/default.webp (video)
sddefault
https://i.ytimg.com/vi/jNQXAC9IVRw/sddefault.jpg (video)
https://stackblitz.com/edit/nuxt-starter-lnbkmh?file=pages%2Findex.vue
Expected the youtube placeholder can show all videos preview thumbnail image.
No response
The text was updated successfully, but these errors were encountered:
I'm doing this to get the best possible quality/format during static site generation:
const defaultPlaceholder = ref<string | null | undefined>(`https://i.ytimg.com/vi/${props.videoId}/sddefault.jpg`) const asyncKey = `youtube-placeholder:${props.videoId}` const { data } = await useAsyncData( asyncKey, async () => { const possibleURLs = [ `https://i.ytimg.com/vi_webp/${props.videoId}/maxresdefault.webp`, `https://i.ytimg.com/vi/${props.videoId}/maxresdefault.jpg`, `https://i.ytimg.com/vi_webp/${props.videoId}/sddefault.webp`, `https://i.ytimg.com/vi/${props.videoId}/sddefault.jpg`, `https://i.ytimg.com/vi_webp/${props.videoId}/hqdefault.webp`, `https://i.ytimg.com/vi/${props.videoId}/hqdefault.jpg`, `https://i.ytimg.com/vi_webp/${props.videoId}/mqdefault.webp`, `https://i.ytimg.com/vi/${props.videoId}/mqdefault.jpg`, `https://i.ytimg.com/vi_webp/${props.videoId}/default.web`, `https://i.ytimg.com/vi/${props.videoId}/default.jpg`, ] for (const urlToTry of possibleURLs) { const response = await $fetch.raw(urlToTry, { method: 'HEAD', mode: 'no-cors', ignoreResponseError: true }) if (response.status === 200) { return urlToTry } } } ) if (data.value) { defaultPlaceholder.value = data.value }
But it does not work on the client due to opaque requests.
Sorry, something went wrong.
Successfully merging a pull request may close this issue.
🐛 The bug
The current youtube placeholder url
https://i.ytimg.com/vi_webp/${props.videoId}/sddefault.webp
cannot show some videos.vi_webp
is not guaranteed to existhttps://i.ytimg.com/vi_webp/mJ8tq8AnNis/default.webp (video)
sddefault
is not guaranteed to existhttps://i.ytimg.com/vi/jNQXAC9IVRw/sddefault.jpg (video)
🛠️ To reproduce
https://stackblitz.com/edit/nuxt-starter-lnbkmh?file=pages%2Findex.vue
🌈 Expected behavior
Expected the youtube placeholder can show all videos preview thumbnail image.
ℹ️ Additional context
No response
The text was updated successfully, but these errors were encountered: