在WordPress开发中,有时会遇到CSS动画无法正常工作的问题,特别是使用@keyframes动画或者JavaScript控制动画的reveal函数时。本文将深入探讨此类问题,并提供一种有效的解决方案。
在WordPress页面中使用CSS动画,例如@keyframes定义的动画,或者使用JavaScript的reveal函数控制元素在滚动时的显示动画,可能会发现动画效果无法正常显示。即使代码在其他环境中(如Visual Studio Code)运行良好,但在WordPress页面中却失效。
这种情况通常是由于以下原因造成的:
一种有效的解决方案是将CSS样式以外链的方式引入WordPress页面,而不是直接嵌入到页面内容中。具体步骤如下:
创建CSS文件: 将包含@keyframes动画和相关样式的CSS代码保存到一个单独的.css文件中,例如style.css。
section1 {
min-height: 400px;
display: flex;
justify-content: center;
align-items: center;
}
.reveal {
position: relative;
opacity: 0;
}
.reveal.active {
opacity: 1;
}
.active.fade-right {
animation: fade-right 1s ease-in;
-webkit-animation: fade-right 1s ease-in;
}
@keyframes fade-right {
0% {
transform: translateX(200px);
-webkit-transform: translateX(200px);
opacity: 0;
}
100% {
transform: translateX(-100px);
-webkit-transform: translateX(-100px);
opacity: 1;
}
}上传CSS文件: 将style.css文件上传到WordPress主题的目录中,例如/wp-content/themes/your-theme/css/。
在主题的header.php文件中引入CSS文件: 在
标签内添加以下代码,引入外部样式表。请确保替换your-theme为你的实际主题名称。
引入JavaScript文件: 将 JavaScript 代码保存为 .js 文件,例如 reveal.js,并将其放置在主题的 JavaScript 目录中(例如 /wp-content/themes/your-theme/js/)。然后在主题的 header.php 或 footer.php 文件中引入该文件。
添加JavaScript代码: 在 reveal.js 文件中添加以下 JavaScript 代码:
function reveal() {
var reveals = document.querySelectorAll(".reveal");
for (var i = 0; i < reveals.length; i++) {
var windowHeight = window.innerHeight;
var elementTop = reveals[i].getBoundingClientRect().top;
var elementVisible = 150;
if (elementTop < windowHeight - elementVisible) {
reveals[i].classList.add("active");
} else {
reveals[i].classList.remove("active");
}
}
}
window.addEventListener("scroll", reveal);HTML结构: 在 WordPress 页面中使用以下 HTML 结构:
Scroll Down to Reveal Elements ↓
Caption
Section Text
Lorem ipsum dolor sit amet consectetur adipisicing elit. Tempore eius molestiae perferendis eos provident vitae iste.
以将JavaScript代码放在标签之前,或者使用DOMContentLoaded事件监听器。通过将CSS样式以外链的方式引入WordPress页面,可以有效绕过经典页面编辑器对@keyframes的限制,解决CSS动画失效的问题。同时,需要注意缓存、样式冲突和JavaScript执行时机等问题,以确保动画效果正常显示。这种方法不仅适用于@keyframes动画,也适用于其他CSS特性和JavaScript控制的动画效果。