Rumah > hujung hadapan web > tutorial css > Petua dan kaedah untuk melaksanakan kesan kaca pembesar dengan CSS

Petua dan kaedah untuk melaksanakan kesan kaca pembesar dengan CSS

王林
Lepaskan: 2023-10-20 14:12:11
asal
2000 orang telah melayarinya

Petua dan kaedah untuk melaksanakan kesan kaca pembesar dengan CSS

Petua dan kaedah CSS untuk mencapai kesan kaca pembesar

Abstrak: CSS memainkan peranan penting dalam reka bentuk web, ia bukan sahaja boleh teks kawalan Dan gaya imej, anda juga boleh mencapai beberapa kesan khas yang hebat. Artikel ini akan memperkenalkan cara menggunakan CSS untuk melaksanakan kesan kaca pembesar dan memberikan contoh kod khusus.

1 Persediaan

Sebelum kita mula, kita memerlukan beberapa sumber imej dan struktur HTML asas.

<!DOCTYPE html>
<html>
<head>
  <link rel="stylesheet" type="text/css" href="style.css">
</head>
<body>
  <div class="container">
    <img src="image.jpg" alt="图片">
    <div class="zoom"></div>
  </div>
</body>
</html>
Salin selepas log masuk

Antaranya, image.jpg ialah imej yang perlu dipaparkan, dan style.css ialah helaian gaya yang akan kami gunakan untuk melaksanakan kesan kaca pembesar. Seterusnya, kami akan menambah gaya kesan khas dalam style.css. image.jpg是需要展示的图片,style.css是我们将用来实现放大镜特效的样式表。接下来,我们将在style.css中添加特效的样式。

二、基本样式

首先,我们需要为图片容器和放大镜创建样式。

.container {
  position: relative;
}

.zoom {
  position: absolute;
  width: 200px;
  height: 200px;
  border: 1px solid #ccc;
  background-color: rgba(255, 255, 255, 0.7);
  pointer-events: none;
  visibility: hidden;
}
Salin selepas log masuk

在这里,我们将图片容器的位置设置为相对定位,以便放大镜样式可以相对于容器定位。放大镜样式具有一些基本的样式,如宽度、高度、边框和背景色。我们通过pointer-events: none;visibility: hidden;将放大镜元素设置为不可见。

三、实现放大镜效果

接下来,我们将使用鼠标事件和CSS来实现放大镜特效。

.zoom:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: 400% 400%;
  background-repeat: no-repeat;
  visibility: hidden;
}

.container:hover .zoom {
  visibility: visible;
}
Salin selepas log masuk

在这里,我们使用伪元素:before为放大镜创建一个遮罩层。遮罩层的样式包括绝对定位、宽度和高度为100%,以及可见性为隐藏。我们通过为遮罩层设置背景图像的大小为400%来实现放大效果。当鼠标悬停在图片容器上时,我们将放大镜的可见性设置为可见。

四、实现移动效果

最后,我们需要为放大的效果添加移动效果。

.container:hover .zoom:before {
  visibility: visible;
}

.container:hover .zoom {
  background-image: url("image.jpg");
}

.container:hover .zoom:before {
  background-image: url("image.jpg");
  transform-origin: 0 0;
}

.container:hover .zoom:before {
  background-position: -100px -100px;
}
Salin selepas log masuk

通过将背景图像设为原始图像,我们可以获得放大的效果。通过将transform-origin设置为0 0

2. Gaya asas

Pertama, kita perlu mencipta gaya untuk bekas imej dan kaca pembesar.

rrreee
Di sini, kami menetapkan kedudukan bekas imej kepada kedudukan relatif supaya gaya kaca pembesar boleh diletakkan secara relatif kepada bekas. Gaya kaca pembesar mempunyai beberapa gaya asas seperti lebar, tinggi, sempadan dan warna latar belakang. Kami menetapkan elemen kaca pembesar menjadi tidak kelihatan melalui pointer-events: none; dan visibility: hidden;.

#🎜🎜#3. Laksanakan kesan kaca pembesar #🎜🎜##🎜🎜#Seterusnya, kami akan menggunakan acara tetikus dan CSS untuk melaksanakan kesan kaca pembesar. #🎜🎜#rrreee#🎜🎜#Di sini, kami menggunakan elemen pseudo :before untuk mencipta lapisan topeng untuk kaca pembesar. Gaya lapisan topeng termasuk kedudukan mutlak, lebar dan ketinggian 100% dan keterlihatan tersembunyi. Kami mencapai kesan pembesaran dengan menetapkan saiz imej latar belakang untuk lapisan topeng kepada 400%. Kami menetapkan keterlihatan kaca pembesar kepada kelihatan apabila tetikus melayang di atas bekas imej. #🎜🎜##🎜🎜# 4. Laksanakan kesan pergerakan #🎜🎜##🎜🎜# Akhir sekali, kita perlu menambah kesan pergerakan pada kesan pembesaran. #🎜🎜#rrreee#🎜🎜# Dengan menetapkan imej latar belakang kepada imej asal, kita boleh mendapatkan kesan yang diperbesarkan. Dengan menetapkan transform-origin kepada 0 0, kami boleh memastikan bahawa kaca pembesar diletakkan dengan betul di penjuru kiri sebelah atas. Akhir sekali, kami mencapai kesan pembesaran dengan menetapkan nilai negatif untuk kedudukan latar belakang lapisan topeng. #🎜🎜##🎜🎜#Ringkasnya, kami berjaya melaksanakan kesan khas kaca pembesar. Melalui struktur HTML yang munasabah dan gaya CSS, kami boleh menambah pelbagai kesan khas dengan mudah untuk meningkatkan pengalaman interaktif halaman web. #🎜🎜##🎜🎜#Rujukan: #🎜🎜#[1] W3Schools [Dalam Talian]https://www.w3schools.com/csSref/css_selectors.php [Diakses pada 24 Ogos #2021]. 🎜🎜#

Atas ialah kandungan terperinci Petua dan kaedah untuk melaksanakan kesan kaca pembesar dengan CSS. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan