使用 :hover 和 :focus 这样的伪类,我们可以很方便的将元素从一个样式切换到另一个样式,而且切换是会有过渡效果。但有时我们想要使用 js 来驱动过渡(即在代码中触发过渡)也是可以实现的。
和普通过渡一样,先创建两个样式规则,一个是元素的初始状态,一个是过渡结束的状态。然后用 js 在合适的事机修改对应元素的样式即可。
下面以一个日夜景图片切换的样例演示:
(1)日景和夜景是两张图片叠在一起的。夜景图初始透明度是0,覆盖在日景图上方。
(2)点击“看夜景”按钮,夜景图透明度逐渐从0过渡到1,看起来画面慢慢变成夜景。
(3)点击“看日景”按钮,夜景图透明度逐渐又从1过渡到0,看起来画面恢复成日景。
在线样例如下:
<!doctype html> <html lang="en"> <head> <title>hangge.com</title> <style> img { position:absolute; transition: opacity 5s; -webkit-transition: opacity 5s; } .solid { opacity: 1; } .transparent { opacity: 0; } </style> <script> function toNight(){ var nightImage = document.getElementById("nightImage"); nightImage.className = "solid"; } function toDay(){ var nightImage = document.getElementById("nightImage"); nightImage.className = "transparent"; } </script> </head> <body> <button onclick="toNight()">看夜景</button> <button onclick="toDay()">看日景</button> <div> <img src="day.png" alt="日景"/> <img src="night.png" alt="夜景" id="nightImage" class="transparent"/> </div> </body> </html>
以上所述是小编给大家介绍的使用JavaScript触发过渡效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对呐喊教程网站的支持!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。