Miten luodaan: Snackbar / Toast
- Edellinen sivu Vastausvaihteleva kelluva
- Seuraava sivu Täysin näyttöikkuna
Opi, miten luot Snackbar/Toast CSS:n ja JavaScriptin avulla.
Snackbar / Toast
Snackbaria käytetään yleensä vihjeen/pop-up-ikkunana, joka näkyy näytön alakulmassa.
Näytä Snackbar painikkeella. Se katoaa 3 sekunnin kuluttua.
Jotain tekstiä, jokin viesti...
Luo Snackbar
Ensimmäinen vaihe - lisää HTML:
<!-- Käytä painiketta avataksesi snackbarin --> <button onclick="myFunction()">Näytä Snackbar</button> <!-- Todellinen snackbar --> <div id="snackbar">Jotain tekstiä, jokin viesti...</div>
Toinen vaihe - lisää CSS:
Aseta snackbarin tyyli ja lisää animaatio:
/* snackbar - sijoita se näytön alakulmaan ja keskelle */ #snackbar { visibility: hidden; /* oletuksena piilotettu, näkyvä klikatessa */ min-width: 250px; /* aseta oletusminimileveys */ margin-left: -125px; /* jakaa min-width:n arvon kahdella */ background-color: #333; /* musta taustaväri */ color: #fff; /* valkoinen tekstiväri */ text-align: center; /* teksti keskellä */ border-radius: 2 px; /* pyöristetty reunaviiva */ padding: 16px; /* 内边距 */ position: fixed; /* 固定在屏幕顶部 */ z-index: 1; /* 如果需要,添加z-index */ left: 50%; /* 将snackbar居中 */ bottom: 30px; /* 距离底部 30px */ } /* 单击按钮时显示 snackbar(使用 JavaScript 添加的类) */ #snackbar.show { visibility: visible; /* Show the snackbar */ /* 添加动画:用0.5秒淡入和淡出 snackbar。但是,将淡出过程延迟 2.5 秒。 */ -webkit-animation: fadein 0.5s, fadeout 0.5s 2.5s; animation: fadein 0.5s, fadeout 0.5s 2.5s; } /* 淡入和淡出 snackbar 的动画 */ @-webkit-keyframes fadein { from {bottom: 0; opacity: 0;} to {bottom: 30px; opacity: 1;} } @keyframes fadein { from {bottom: 0; opacity: 0;} to {bottom: 30px; opacity: 1;} } @-webkit-keyframes fadeout { from {bottom: 30px; opacity: 1;} to {bottom: 0; opacity: 0;} } @keyframes fadeout { from {bottom: 30px; opacity: 1;} to {bottom: 0; opacity: 0;} }
第三步 - 添加 JavaScript:
使用 JavaScript 通过点击按钮向 snackbar 容器添加 "show" 类:
function myFunction() { // 获取 snackbar DIV var x = document.getElementById("snackbar"); // 向 DIV 添加 "show" 类 x.className = "show"; // 3秒后,从 DIV 中删除 "show" 类 setTimeout(function(){ x.className = x.className.replace("show", ""); }, 3000); }
- Edellinen sivu Vastausvaihteleva kelluva
- Seuraava sivu Täysin näyttöikkuna