如果页面加载时间过长,则隐藏一个元素并显示另一个元素
Hide an element and show another if page is taking too long to load
如果页面加载时间过长,是否可以隐藏一个元素然后显示另一个元素?
情况:我有一个带有背景视频的 header,如果有人连接速度慢并且无法加载背景视频,则将 header 元素替换为另一个具有静态背景的 header 元素图片。
谢谢
这不是我通常推荐的东西,但这里有一个非常老套的解决方案。
const video = document.querySelector("#video-element-id");
let tooSlow = false;
let timeout = setTimeout(() => {
tooSlow = true;
...logic to change header
clearTimeout(timeout);
}, 1000);
video.addEventListener('loadeddata', () => {
console.log(tooSlow ? 'too slow' : 'loaded');
clearTimeout(timeout);
});
* 编辑 - 或者您可以对承诺 tbf
做同样的事情
const video = document.querySelector("#video-element-id");
const loader = new Promise((resolve) => {
let timeout = setTimeout(() => {
resolve(false);
}, 0);
video.addEventListener('loadeddata', () => {
resolve(true);
});
});
loader
.then((isLoaded) => {
if (isLoaded) {
console.log('loaded');
return;
}
console.log('too slow');
...logic to change header
});
尽管 header 已切换,但仍然存在视频将继续下载的问题。更好的解决方案可能是使用 poster
属性来显示视频的静止图像,直到它完成加载:) https://developer.mozilla.org/en-US/docs/Web/HTML/Element/video#attr-poster
如果页面加载时间过长,是否可以隐藏一个元素然后显示另一个元素? 情况:我有一个带有背景视频的 header,如果有人连接速度慢并且无法加载背景视频,则将 header 元素替换为另一个具有静态背景的 header 元素图片。
谢谢
这不是我通常推荐的东西,但这里有一个非常老套的解决方案。
const video = document.querySelector("#video-element-id");
let tooSlow = false;
let timeout = setTimeout(() => {
tooSlow = true;
...logic to change header
clearTimeout(timeout);
}, 1000);
video.addEventListener('loadeddata', () => {
console.log(tooSlow ? 'too slow' : 'loaded');
clearTimeout(timeout);
});
* 编辑 - 或者您可以对承诺 tbf
做同样的事情const video = document.querySelector("#video-element-id");
const loader = new Promise((resolve) => {
let timeout = setTimeout(() => {
resolve(false);
}, 0);
video.addEventListener('loadeddata', () => {
resolve(true);
});
});
loader
.then((isLoaded) => {
if (isLoaded) {
console.log('loaded');
return;
}
console.log('too slow');
...logic to change header
});
尽管 header 已切换,但仍然存在视频将继续下载的问题。更好的解决方案可能是使用 poster
属性来显示视频的静止图像,直到它完成加载:) https://developer.mozilla.org/en-US/docs/Web/HTML/Element/video#attr-poster