如何创建:标签页式图片库

学习如何使用 CSS 和 JavaScript 创建标签页式图片库。

标签页式图片库

点击图像可展开:

หวหั่นหนาน
ปักกิ่ง
เซินเจิ้น
ฮังโจว
×

亲自试一试

创建标签页画廊

第一步 - 添加 HTML:

<!-- 网格:四列 -->
<div class="row">
  <div class="column">
    <img src="img_nature.jpg" alt="Nature" onclick="myFunction(this);">
  </div>
  <div class="column">
    <img src="img_snow.jpg" alt="Snow" onclick="myFunction(this);">
  </div>
  <div class="column">
    <img src="img_mountains.jpg" alt="Mountains" onclick="myFunction(this);">
  </div>
  <div class="column">
    <img src="img_lights.jpg" alt="Lights" onclick="myFunction(this);">
  </div>
</div>
<!-- 展开的图像容器 -->
<div class="container">
  <!-- 关闭图像 -->
  <span onclick="this.parentElement.style.display='none'" class="closebtn">×</span>
  <!-- 扩展图像 -->
  <img id="expandedImg" style="width:100%">
  <!-- 图像文本 -->
  <div id="imgtext"></div>
</div>

ใช้ภาพเพื่อขยายภาพเฉพาะที่กำหนดไว้。หลังจากกดภาพในคอลัมน์ ภาพนั้นจะถูกแสดงในกงด้านล่างของคอลัมน์

ขั้นที่ 2 - เพิ่ม CSS:

สร้างสี่คอลัมน์และตั้งรูปแบบภาพ:

/* กง: สี่คอลัมน์ที่วางแนวตรง */
.column {
  float: left;
  width: 25%;
  padding: 10px;
}
/* ตั้งรูปแบบของภาพในกง */
.column img {
  opacity: 0.8;
  cursor: pointer;
}
.column img:hover {
  opacity: 1;
}
/* ล้างการลอยหลังจากคอลัมน์ */
.row:after {
  content: "";
  display: table;
  clear: both;
}
/* กงที่ภาพที่ขยาย (จำเป็นต้องใช้การจัดตำแหน่งเพื่อจัดทำปุ่มปิดและข้อความ) */
.container {
  position: relative;
  display: none;
}
/* ข้อความภาพที่ขยาย */
#imgtext {
  position: absolute;
  bottom: 15px;
  left: 15px;
  color: white;
  font-size: 20px;
}
/* ปุ่มปิดภาพที่ภายในภาพ */
.closebtn {
  position: absolute;
  top: 10px;
  right: 15px;
  color: white;
  font-size: 35px;
  cursor: pointer;
}

ขั้นที่ 3 - เพิ่ม JavaScript:

function myFunction(imgs) {
  // ค้นหาภาพที่ขยาย
  var expandImg = document.getElementById("expandedImg");
  // ค้นหาข้อความภาพ
  var imgText = document.getElementById("imgtext");
  // ใช้ src ที่เหมือนกันกับภาพที่กดในรูปแบบตาราง
  expandImg.src = imgs.src;
  // ใช้ค่าของ alt ที่ใช้ในภาพที่สามารถคลิกเพื่อแสดงข้อความภายในภาพที่ขยาย
  imgText.innerHTML = imgs.alt;
  // แสดงออกตัวเลือกประกอบฝากลั่น (ซ่อนด้วย CSS)
  expandImg.parentElement.style.display = "block";
}

亲自试一试