Rumah > hujung hadapan web > tutorial css > Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

青灯夜游
Lepaskan: 2022-03-07 19:39:17
ke hadapan
2416 orang telah melayarinya

Artikel ini akan berkongsi dengan anda 12 petua CSS yang menarik dan praktikal untuk memudahkan pembangunan bahagian hadapan. Saya harap ia akan membantu semua orang.

Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

(Pembelajaran yang disyorkan: tutorial video css)

1. Kesan menaip

Pelaksanaan kod:

<div class="wrapper">
    <div class="typing-demo">
      有趣且实用的 CSS 小技巧
    </div>
</div>
Salin selepas log masuk
.wrapper {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.typing-demo {
  width: 22ch;
  animation: typing 2s steps(22), blink .5s step-end infinite alternate;
  white-space: nowrap;
  overflow: hidden;
  border-right: 3px solid;
  font-family: monospace;
  font-size: 2em;
}

@keyframes typing {
  from {
    width: 0
  }
}
    
@keyframes blink {
  50% {
    border-color: transparent
  }
}
Salin selepas log masuk

Mencapai kesan:

Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

2. Tetapkan bayang

Apabila menggunakan imej lutsinar, anda boleh menggunakan bayang-bayang jatuh ( ) fungsi mencipta bayang pada imej, bukannya menggunakan sifat bayang kotak untuk mencipta bayang segi empat tepat di belakang keseluruhan kotak elemen:

<div class="wrapper">
  <div class="mr-2">
    <div class="mb-1 text-center">
      box-shadow
    </div>
    
    <img class="box-shadow" src="https://markodenic.com/man_working.png" alt="Image with box-shadow">
  </div>
    
  <div>
    <div class="mb-1 text-center">
      drop-shadow
    </div>
    
    <img class="drop-shadow" src="https://markodenic.com/man_working.png" alt="Image with drop-shadow">
  </div>
</div>
Salin selepas log masuk
.wrapper {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mr-2 {
  margin-right: 2em;
}

.mb-1 {
  margin-bottom: 1em;
}

.text-center {
  text-align: center;
}

.box-shadow {
  box-shadow: 2px 4px 8px #585858;
}

.drop-shadow {
  filter: drop-shadow(2px 4px 8px #585858);
}
Salin selepas log masuk

Kesan kontras:

Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

3. Penatalan lancar

Tiada JavaScript diperlukan untuk mencapai penatalan lancar, hanya satu baris CSS: tatal-kelakuan: lancar;

<nav>
  Scroll to: 
  <a href="#sectionA" class="link bg-red">A</a>
  
  <a href="#sectionB" class="link bg-blue">B</a>
  
  <a href="#sectionC" class="link bg-green">C</a>
</nav>

<div class="wrapper">
  <div id="sectionA" class="section bg-red">A</div>
  
  <div id="sectionB" class="section bg-blue">B</div>
  
  <div id="sectionC" class="section bg-green">C</div>
</div>
Salin selepas log masuk
html {
  scroll-behavior: smooth;
}

nav {
  position: fixed;
  left: calc(50vw - 115px);
  top: 0;
  width: 200px;
  text-align: center;
  padding: 15px;
  background: #fff;
  box-shadow: 0 2px 5px 1px rgba(0, 0, 0, 0.2);
}

nav .link {
  padding: 5px;
  color: white;
}

.section {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 5em;
  text-shadow:
    0px 2px 0px #b2a98f,
    0px 4px 3px rgba(0,0,0,0.15),
    0px 8px 1px rgba(0,0,0,0.1);
}

.bg-red {
  background: #de5448;
}

.bg-blue {
  background: #4267b2;
}

.bg-green {
  background: #4CAF50;
}
Salin selepas log masuk

Mencapai kesan:

4 Kursor tersuai

Kami boleh menggunakan imej tersuai atau malah emoji sebagai kursor.

<div class="wrapper">
  <div class="tile">
    Default
  </div>
  
  <div class="tile tile-image-cursor">
    Image
  </div>
  
  <div class="tile tile-emoji-cursor">
    Emoji
  </div>
</div>
Salin selepas log masuk
.wrapper {
  display: flex;
  height: 100vh;
  align-items: center;
  justify-content: center;
  background: #4776e6;
  background: linear-gradient(to right, #4776e6, #8e54e9);
  padding: 0 10px;
}

.tile {
    width: 200px;
    height: 200px;display: flex;
    align-items: center;
    justify-content: center;
    background-color: #de5448;
    margin-right: 10px;color: #fff;
    font-size: 1.4em;
    text-align: center;
  }

.tile-image-cursor {
  background-color: #1da1f2;
  cursor: url(https://picsum.photos/20/20), auto;
}

.tile-emoji-cursor {
  background-color: #4267b2;
  cursor: url("data:image/svg+xml;utf8,<svg xmlns=&#39;http://www.w3.org/2000/svg&#39;  width=&#39;40&#39; height=&#39;48&#39; viewport=&#39;0 0 100 100&#39; style=&#39;fill:black;font-size:24px;&#39;><text y=&#39;50%&#39;>?</text></svg>"), auto;
}
Salin selepas log masuk

Mencapai kesan:

Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

5 Potong teks

Barisan teks melimpah dan bersembunyi:

<div>
	白日依山尽,黄河入海流。欲穷千里目,更上一层楼。
</div>
Salin selepas log masuk
div {
  width: 200px;
  background-color: #fff;
  padding: 15px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
Salin selepas log masuk

Mencapai kesan:

Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

Anda juga boleh menggunakan atribut "-webkit-line-clamp" untuk memotong teks kepada bilangan baris tertentu. Teks akan memaparkan elipsis di tempat yang dipotong:

div {
  width: 200px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
Salin selepas log masuk

Mencapai kesan:

5-Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

6 Sesuaikan gaya pemilihan

CSS Pseudo element::selection boleh digunakan untuk menyesuaikan gaya penyerlahan dokumen yang dipilih oleh pengguna.

<div class="wrapper">
  <div>
    <p>
     默认高亮
    </p>
    <p class="custom-highlighting">
      自定义高亮
    </p>
  </div>
</div>
Salin selepas log masuk
.wrapper {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

p {
  font-size: 2rem;
  font-family: sans-serif;
}

.custom-highlighting::selection {
  background-color: #8e44ad;
  color: #fff;
}
Salin selepas log masuk

Mencapai kesan:

Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

6-Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

7. Kotak modal CSS

Kita boleh menggunakan :target pseudo-element dalam CSS untuk mencipta kotak modal.

<div class="wrapper">
    <a href="#demo-modal">Open Modal</a>
</div>

<div id="demo-modal" class="modal">
    <div class="modal__content">
        <h1>CSS Modal</h1>
        <p>hello world</p>
        <a href="#" class="modal__close">&times;</a>
    </div>
</div>
Salin selepas log masuk
.wrapper {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(to right, #834d9b, #d04ed6);
}

.wrapper a {
  display: inline-block;
  text-decoration: none;
  padding: 15px;
  background-color: #fff;
  border-radius: 3px;
  text-transform: uppercase;
  color: #585858;
  font-family: &#39;Roboto&#39;, sans-serif;
}

.modal {
  visibility: hidden;
  opacity: 0;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(77, 77, 77, .7);
  transition: all .4s;
}

.modal:target {
  visibility: visible;
  opacity: 1;
}

.modal__content {
  border-radius: 4px;
  position: relative;
  width: 500px;
  max-width: 90%;
  background: #fff;
  padding: 1em 2em;
}

.modal__close {
  position: absolute;
  top: 10px;
  right: 10px;
  color: #585858;
  text-decoration: none;
}
Salin selepas log masuk

Mencapai kesan:

Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

8 Gaya elemen kosong

boleh ditetapkan sepenuhnya menggunakan :empty pemilih Gaya untuk elemen tanpa elemen atau teks anak:

<div class="wrapper">
  <div class="box"></div>
  <div class="box">白日依山尽,黄河入海流。欲穷千里目,更上一层楼。</div>
</div>
Salin selepas log masuk
.wrapper {
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
}

.box {
  display: inline-block;
  background: #999;
  border: 1px solid #585858;
  height: 200px;
  width: 200px;
  margin-right: 15px;
}

.box:empty {
  background: #fff;
}
Salin selepas log masuk

Kesan pelaksanaan:

Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

9. Cipta bar skrol tersuai

<div class="wrapper">
    <div>
      <div class="tile mr-1">
        <div class="tile-content">
          默认滚动条
        </div>
      </div>
      
      <div class="tile tile-custom-scrollbar">
        <div class="tile-content">
          自定义滚动条
        </div>
      </div>
    </div>
</div>
Salin selepas log masuk
.wrapper {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mr-1 {
  margin-right: 1em;
}

.tile {
  overflow: auto;
  display: inline-block;
  background-color: #ccc;
  height: 200px;
  width: 180px;
}

.tile-custom-scrollbar::-webkit-scrollbar {
  width: 12px;
  background-color: #eff1f5;
}

.tile-custom-scrollbar::-webkit-scrollbar-track{
  border-radius: 3px;
  background-color: transparent;
}

.tile-custom-scrollbar::-webkit-scrollbar-thumb{
  border-radius:5px;
  background-color:#515769;
  border:2px solid #eff1f5
}

.tile-content {
  padding: 20px;
  height: 500px;
}
Salin selepas log masuk

Mencapai kesan:

Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

10 Petua alat dinamik

Anda boleh menggunakan fungsi CSS attr() untuk mencipta dinamik. petua alat tulen Petua alat CSS.

<h1>
  HTML/CSS tooltip
</h1>
<p>
  Hover <span class="tooltip" data-tooltip="Tooltip Content">Here</span> to see the tooltip.
</p>
<p>
  You can also hover <span class="tooltip" data-tooltip="This is another Tooltip Content">here</span> to see another example.
</p>
Salin selepas log masuk
.tooltip {
  position: relative;
  border-bottom: 1px dotted black;
}

.tooltip:before {
  content: attr(data-tooltip); 
  position: absolute;
  width: 100px;
  background-color: #062B45;
  color: #fff;
  text-align: center;
  padding: 10px;
  line-height: 1.2;
  border-radius: 6px;
  z-index: 1;
  opacity: 0;
  transition: opacity .6s;
  bottom: 125%;
  left: 50%;
  margin-left: -60px;
  font-size: 0.75em;
  visibility: hidden;
}

.tooltip:after {
  content: "";
  position: absolute;
  bottom: 75%;
  left: 50%;
  margin-left: -5px;
  border-width: 5px;
  border-style: solid;
  opacity: 0;
  transition: opacity .6s;
  border-color: #062B45 transparent transparent transparent;
  visibility: hidden;
}

.tooltip:hover:before, 
.tooltip:hover:after {
  opacity: 1;
  visibility: visible;
}
Salin selepas log masuk

Mencapai kesan:

Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

10-Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

11. Sempadan kecerunan bulat

<div class="box gradient-border">
  炫酷渐变边框
</div>
Salin selepas log masuk
.gradient-border {
  border: solid 5px transparent;
  border-radius: 10px;
  background-image: linear-gradient(white, white), 
    linear-gradient(315deg,#833ab4,#fd1d1d 50%,#fcb045);
  background-origin: border-box;
  background-clip: content-box, border-box;
}

.box {
  width: 350px;
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 100px auto;
}
Salin selepas log masuk

Mencapai kesan:

1Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

12 Imej skala kelabu

Anda boleh menggunakan fungsi penapis skala kelabu() untuk menukar imej input. kepada kelabu Belanja.

1Kongsi 12 petua CSS praktikal (datang dan kumpulkan)

(Belajar perkongsian video: Tutorial pengenalan bahagian hadapan web)

Atas ialah kandungan terperinci Kongsi 12 petua CSS praktikal (datang dan kumpulkan). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
css
sumber:juejin.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