占位图片(Placeholder Image)

avatar
cmdragon 渡劫
image

一、引言

在网页设计和开发中,占位图片(Placeholder Image)是一种常见的技术手段,用于在用户上传图片之前或者图片加载失败时,展示一个临时替代的图片,以提高用户体验。本文将详细介绍占位图片的实现原理和实践应用,并通过实例给出不同场景下的解决方案。

占位图片生成器 | 一个覆盖广泛主题工具的高效在线平台(amd794.com)

https://amd794.com/placeholder

二、占位图片实现原理

1. CSS实现

通过CSS的::before::after伪元素,可以在元素内部插入占位图片。以下是一个简单的示例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>占位图片实现</title>
<style>
.placeholder {
width: 200px;
height: 200px;
background-image: url('https://amd794.com/upload/images/cmder/200_X_200_L8fk0kE.png');
background-size: cover;
background-position: center;
}

.placeholder::before {
content: "";
display: block;
width: 100%;
height: 100%;
background-image: url('https://amd794.com/upload/images/cmder/200_X_200_L8fk0kE.png');
background-size: cover;
background-position: center;
}
</style>
</head>
<body>
<div class="placeholder"></div>
</body>
</html>

2. JavaScript实现

通过JavaScript,可以在图片加载失败时,切换到占位图片。以下是一个简单的示例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>占位图片实现</title>
</head>
<body>
<img id="main-img" src="https://amd794.com/upload/images/cmder/200_X_200_L8fk0kE.png" alt="占位图片">

<script>
const mainImg = document.getElementById('main-img');

mainImg.addEventListener('error', () => {
mainImg.onerror = null;
mainImg.src = 'https://amd794.com/upload/images/cmder/200_X_200_L8fk0kE.png';
});

mainImg.addEventListener('load', () => {
mainImg.onload = null;
});
</script>
</body>
</html>

三、占位图片实践应用

1. 用户上传图片前的前置处理

在用户上传图片前,可以通过占位图片展示一个临时替代的图片,以防止用户上传空白图片或无法加载的图片。在上传成功后,再替换为实际上传的图片。

2. 图片懒加载

在网页中,可以通过占位图片实现图片的懒加载,提高网页加载速度。当用户滚动到图片所在区域时,再异步加载实际图片。

3. 图片对比展示

在图片对比的场景下,可以使用占位图片展示两个图片的差异。在对比过程中,将实际图片与占位图片进行比较,突出展示差异部分。

4. 图片验证

通过占位图片,可以对用户上传的图片进行验证,如大小、格式、分辨率等。若不符合要求,则展示错误提示信息。

四、总结

占位图片技术在网页设计和开发中具有广泛的应用,通过CSS和JavaScript可以实现占位图片的不同效果。在实际项目中,可以根据需求选择合适的实现方式,提高用户体验和网页性能。