我正在弄清楚如何使用时间日期条件向wordpress body元素添加类,有一个例子:
jQuery(document).ready(function() {
function applyclass()
{
var d = new Date();
var n = d.getHours();
if (n > 20 && n < 06)
jQuery('body').addClass('night');
else if (n > 16 && n < 19)
jQuery('body').addClass('sunset');
else
jQuery('body').addClass('day');
}
window.onload = applyclass;
});
我检查了所有内容,包括文件夹位置和没有控制台错误,但问题是这个脚本没有执行。
谢谢!
答案 0 :(得分:2)
使用
向body函数添加类会更好 <body <?php body_class($class); ?>>
比用jQuery重写它。参见
http://codex.wordpress.org/Function_Reference/body_class#Add_Classes_By_Filters
关于如何挂钩主题的functions.php文件中的body类。
答案 1 :(得分:1)
您的if语句正在测试错误的条件。
if (n > 20 && n < 06)
jQuery('body').addClass('night');
n
不能大于20且小于6.(您在数字上也不需要前面的零;我认为它不是错误但是没有必要)
您也不需要window.onload
部分,因为整个代码块只会在文档加载后执行。相反,您只需在document.ready中调用applyclass()
并将该函数移出块。
但除此之外,代码没有任何问题,逻辑是错误的。弄清楚你想要它做什么,并改变if语句的条件,它应该有效。
答案 2 :(得分:0)
尝试删除window.onload语句。这是多余的。用你的函数调用替换它:
applyclass();
第一行:
jQuery(document).ready(function() {
已经确保在加载DOM之前不会运行它。
答案 3 :(得分:0)
我找到了一个解决方案,我删除了jQuery(文档).ready(function(){}并修改了一些语句,它现在正常工作。这是解决我的问题的片段,随意优化这个片段。谢谢你回答我的问题!
function applyclass()
{
var d = new Date();
var n = d.getHours();
if (n == 5)
jQuery('body').addClass('night');
if (n == 4)
jQuery('body').addClass('night');
if (n == 3)
jQuery('body').addClass('night');
if (n == 2)
jQuery('body').addClass('night');
if (n == 1)
jQuery('body').addClass('night');
if (n == 0)
jQuery('body').addClass('night');
if (n == 23)
jQuery('body').addClass('night');
if (n == 22)
jQuery('body').addClass('night');
if (n == 21)
jQuery('body').addClass('night');
if (n == 20)
jQuery('body').addClass('night');
else if (n == 6)
jQuery('body').addClass('sunset');
else if (n == 7)
jQuery('body').addClass('sunset');
else if (n == 8)
jQuery('body').addClass('sunset');
else if (n == 18)
jQuery('body').addClass('sunset');
else if (n == 19)
jQuery('body').addClass('sunset');
else if (n == 9)
jQuery('body').addClass('day');
else if (n == 10)
jQuery('body').addClass('day');
else if (n == 11)
jQuery('body').addClass('day');
else if (n == 12)
jQuery('body').addClass('day');
else if (n == 13)
jQuery('body').addClass('day');
else if (n == 14)
jQuery('body').addClass('day');
else if (n == 15)
jQuery('body').addClass('day');
else if (n == 16)
jQuery('body').addClass('day');
else if (n == 17)
jQuery('body').addClass('day');
}
window.onload = applyclass;
答案 4 :(得分:0)
我知道你可能不会寻找PHP功能,但这就是我所做的。这可以添加到functions.php中 https://gist.github.com/Garconis/11e7e4c316b4f5c4e5dfcbe7d916f5c3
<?php
// Add the times and days to the body classes
// e.g., date-day-wednesday date-ymd-20170614 date-month-june time-military-1317 time-pm time-early-afternoon
add_filter( 'body_class', 'add_date_info_to_class_names' );
function add_date_info_to_class_names( $classes ) {
// current day of week name
$classes[] = 'date-day-' . strtolower(date_i18n('l'));
// current full date YYYYMMDD
$classes[] = 'date-ymd-' . strtolower(date_i18n('Ymd'));
// current month name
$classes[] = 'date-month-' . strtolower(date_i18n('F'));
// current military time HHMM
$classes[] = 'time-military-' . strtolower(date_i18n('Hi'));
// check hour and add am or pm class
if ( date_i18n('H') >= 12 ){
$classes[] = 'time-pm';
} else {
$classes[] = 'time-am';
}
// check hour and add time of day descriptor
if (preg_match("/(00|01|02)/i", date_i18n('H'))){
$classes[] = 'time-early-night';
}
elseif (preg_match("/(03|04|05)/i", date_i18n('H'))){
$classes[] = 'time-late-night';
}
elseif (preg_match("/(06|07|08)/i", date_i18n('H'))){
$classes[] = 'time-early-morning';
}
elseif (preg_match("/(09|10|11)/i", date_i18n('H'))){
$classes[] = 'time-late-morning';
}
elseif (preg_match("/(12|13|14)/i", date_i18n('H'))){
$classes[] = 'time-early-afternoon';
}
elseif (preg_match("/(15|16|17)/i", date_i18n('H'))){
$classes[] = 'time-late-afternoon';
}
elseif (preg_match("/(18|19|20)/i", date_i18n('H'))){
$classes[] = 'time-early-evening';
}
elseif (preg_match("/(21|22|23)/i", date_i18n('H'))){
$classes[] = 'time-late-evening';
}
return $classes;
}