0

我正在尝试使用a:hoverWordpress 为单个页面上的三个不同文章分配三种不同的颜色。

这是网站http://paragrams.wpshower.com/

目前所有文章都变成淡黄色了a:hover。我正在尝试为每篇文章创建不同的颜色(例如,第一篇文章为黄色,第二篇文章为红色,第三篇文章为蓝色等)。

下面是目前的 php & CSS a:hover。我假设我需要将每个拇指 id 包装在不同的 div 中并在 CSS 中指定颜色?

PHP:

<ul class="mcol">
          <?php if(have_posts()) : ?><?php while(have_posts()) : the_post(); ?>
            <li class="article">

                    <?php
                    if ( has_post_thumbnail() ) { ?>
                    <?php 
                    $imgsrcparam = array(
                    'alt'   => trim(strip_tags( $post-    >post_excerpt )),
                    'title' => trim(strip_tags( $post-    >post_title )),
                    );
                    $thumbID = get_the_post_thumbnail( $post->ID, 'background',     $imgsrcparam ); ?>



                    <div><a href="<?php the_permalink() ?>" class="preview"><?php echo     "$thumbID"; ?></a></div>
                    <?php } ?>


                <h2><a href="<?php the_permalink(); ?>" title="<?php the_title(); ?>"><?php the_title(); ?></a></h2>

和 CSS:

.li_container {
background-attachment: scroll;
background-image: url(images/main-bg.gif);
background-repeat: repeat-y;
background-position: left top;
}
.li_container .article:hover {
background-color:#57bfeb;
}

这是js:

  #  * Splits a <ul>/<ol>-list into equal-sized columns. 
#  *  
#  * Requirements:  
#  * <ul> 
#  * <li>"ul" or "ol" element must be styled with margin</li> 
#  * </ul> 
#  *  
#  * @see http://www.codeasily.com/jquery/multi-column-list-with-jquery 
#  */  
jQuery.fn.makeacolumnlists = function(settings){
settings = jQuery.extend({
    cols: 3,                // set number of columns
    colWidth: 0,            // set width for each column or leave 0 for     auto width
    equalHeight: 'li',  // can be false, 'ul', 'ol', 'li'
    startN: 1               // first number on your ordered list
}, settings);

if(jQuery('> li', this)) {
    this.each(function(y) {
        var y=jQuery('.li_container').size(),
            height = 0, 
            maxHeight = 0,
            t = jQuery(this),
            classN = t.attr('class'),
            listsize = jQuery('> li', this).size(),
            percol = Math.ceil(listsize/settings.cols),
            contW = t.width(),
            bl = ( isNaN(parseInt(t.css('borderLeftWidth'),10)) ? 0 :     parseInt(t.css('borderLeftWidth'),10) ),
            br = ( isNaN(parseInt(t.css('borderRightWidth'),10)) ? 0 :     parseInt(t.css('borderRightWidth'),10) ),
            pl = parseInt(t.css('paddingLeft'),10),
            pr = parseInt(t.css('paddingRight'),10),
            ml = parseInt(t.css('marginLeft'),10),
            mr = parseInt(t.css('marginRight'),10),
            col_Width = Math.floor((contW - (settings.cols-1)*(bl+br+pl+pr+ml+mr))/settings.cols);
        if (settings.colWidth) {
            col_Width = settings.colWidth; 
        }
        var colnum=1,
            percol2=percol;
        jQuery(this).addClass('li_cont1').wrap('<div id="li_container' + (++y) + '" class="li_container"></div>');
        for (var i=0; i<=listsize; i++) {
            if (colnum > settings.cols) colnum = 1;
            var eq = jQuery('> li:eq('+i+')',this);
            eq.addClass('li_col'+colnum);
            colnum++;
            //if(i>=percol2) { percol2+=percol; colnum++; }
            //var eq = jQuery('> li:eq('+i+')',this);
            //eq.addClass('li_col'+ colnum);
            //if(jQuery(this).is('ol')){eq.attr('value', ''+(i+settings.startN))+'';}
        }
        jQuery(this).css({cssFloat:'left', width:''+col_Width+'px'});
        for (colnum=2; colnum<=settings.cols; colnum++) {
            if(jQuery(this).is('ol')) {
                jQuery('li.li_col'+ colnum, this).appendTo('#li_container' + y).wrapAll('<ol class="li_cont'+colnum +' ' + classN + '" style="float:left; width: '+col_Width+'px;"></ol>');
            } else {
                jQuery('li.li_col'+ colnum, this).appendTo('#li_container' + y).wrapAll('<ul class="li_cont'+colnum +' ' + classN + '" style="float:left; width: '+col_Width+'px;"></ul>');
            }
        }
        if (settings.equalHeight=='li') {
            for (colnum=1; colnum<=settings.cols; colnum++) {
                jQuery('#li_container'+ y +' li').each(function() {
                    var e = jQuery(this);
                    var border_top = ( isNaN(parseInt(e.css('borderTopWidth'),10)) ? 0 : parseInt(e.css('borderTopWidth'),10) );
                    var border_bottom = ( isNaN(parseInt(e.css('borderBottomWidth'),10)) ? 0 : parseInt(e.css('borderBottomWidth'),10) );
                    height = e.height() + parseInt(e.css('paddingTop'), 10) + parseInt(e.css('paddingBottom'), 10) + border_top + border_bottom;
                    maxHeight = (height > maxHeight) ? height : maxHeight;
                });
            }
            for (colnum=1; colnum<=settings.cols; colnum++) {
                var eh = jQuery('#li_container'+ y +' li');
                var border_top = ( isNaN(parseInt(eh.css('borderTopWidth'),10)) ? 0 : parseInt(eh.css('borderTopWidth'),10) );
                var border_bottom = ( isNaN(parseInt(eh.css('borderBottomWidth'),10)) ? 0 : parseInt(eh.css('borderBottomWidth'),10) );
                mh = maxHeight - (parseInt(eh.css('paddingTop'), 10) + parseInt(eh.css('paddingBottom'), 10) + border_top + border_bottom );
                eh.height(mh);
            }
        } else 
        if (settings.equalHeight=='ul' || settings.equalHeight=='ol') {
            for (colnum=1; colnum<=settings.cols; colnum++) {
                jQuery('#li_container'+ y +' .li_cont'+colnum).each(function() {
                    var e = jQuery(this);
                    var border_top = (     isNaN(parseInt(e.css('borderTopWidth'),10)) ? 0 : parseInt(e.css('borderTopWidth'),10) );
                    var border_bottom = ( isNaN(parseInt(e.css('borderBottomWidth'),10)) ? 0 : parseInt(e.css('borderBottomWidth'),10)     );
                    height = e.height() + parseInt(e.css('paddingTop'),     10) + parseInt(e.css('paddingBottom'), 10) + border_top + border_bottom;
                    maxHeight = (height > maxHeight) ? height :     maxHeight;
                });
            }
            for (colnum=1; colnum<=settings.cols; colnum++) {
                var eh = jQuery('#li_container'+ y +'     .li_cont'+colnum);
                var border_top = (     isNaN(parseInt(eh.css('borderTopWidth'),10)) ? 0 : parseInt(eh.css('borderTopWidth'),10) );
                var border_bottom = ( isNaN(parseInt(eh.css('borderBottomWidth'),10)) ? 0 : parseInt(eh.css('borderBottomWidth'),10) );
                mh = maxHeight - (parseInt(eh.css('paddingTop'), 10) + parseInt(eh.css('paddingBottom'), 10) + border_top + border_bottom );
                /*eh.height(mh);*/
            }
        }
        jQuery('#li_container' + y).append('<div style="clear:both; overflow:hidden; height:0px;"></div>');
    });
}
}

jQuery.fn.uncolumnlists = function(){
jQuery('.li_cont1').each(function(i) {
    var onecolSize = jQuery('#li_container' + (++i) + ' .li_cont1 > li').size();
    if(jQuery('#li_container' + i + ' .li_cont1').is('ul')) {
        jQuery('#li_container' + i + ' > ul > li').appendTo('#li_container'     + i + ' ul:first');
        for (var j=1; j<=onecolSize; j++) {
            jQuery('#li_container' + i + ' ul:first li').removeAttr('class').removeAttr('style');
        }
        jQuery('#li_container' + i + ' ul:first').removeAttr('style').removeClass('li_cont1').insertBefore('#li_container' + i);
    } else {
        jQuery('#li_container' + i + ' > ol > li').appendTo('#li_container' + i + ' ol:first');
        for (var j=1; j<=onecolSize; j++) {
            jQuery('#li_container' + i + ' ol:first li').removeAttr('class').removeAttr('style');
        }
        jQuery('#li_container' + i + ' ol:first').removeAttr('style').removeClass('li_cont1').insertBefore('#li_container' + i);
    }
    jQuery('#li_container' + i).remove();
});
}
4

3 回答 3

2

你不需要对 div 做任何花哨的事情;只需给每个li标签一个唯一的类,并在 css 中指定这些类的颜色。

从您的代码中,您可以更改该行

<li class="article">

<?php
switch($post->ID) {
    case 1:
        $class = 'yellow';    break;
    case 2:
        $class = 'blue';      break;
    case 3:
        $class = 'green';     break;
}
?>
<li class="article <?php echo $class; ?>">

这将有效地输出class='article yellow'第一篇文章、class='article blue'第二篇文章等。然后您可以通过如下更改 css 来完成所有工作:

.li_container .article.yellow:hover { background-color:#57bfeb; }
.li_container .article.green:hover  { background-color:green; }
.li_container .article.blue:hover   { background-color:blue; }

如果你想变得花哨,你也可以换成switch($post->ID)switch(mod($post->ID,3))很多颜色的变化。

于 2011-02-18T17:17:49.240 回答
0

eykanal 有一个很好的解决方案。只是为了放弃另一个选项,您可以使用 jquery 并根据 dom 中的文章位置动态添加类。就像是:

将其添加到页面的 head 元素中:

<script type="text/javascript"src="https://ajax.googleapis.com/ajax/libs/jquery/1.5.0/jquery.min.js"></script>
<script type="text/javascript">
  $(document).ready(function () {
    $('.mcol li.article:nth-child(1)').addClass('yellow')
    $('.mcol li.article:nth-child(2)').addClass('red')
    $('.mcol li.article:nth-child(3)').addClass('blue') 
  });
</script>

然后,您将在您的 css 文件中添加类似这样的内容:

.yellow:hover { background-color: yellow; }
.red:hover { background-color: red; }
.blue:hover { background-color: blue; }

当然,将颜色更改为您选择的十六进制代码。玩得开心!

于 2011-02-18T17:46:51.980 回答
0

我个人会做的是使用 PHP 添加一个递增类,就像这样..

<ul class="mcol">
<?php if(have_posts()) : $i = 0; while(have_posts()) : the_post(); $i++; ?>
    <li class="article <?php echo "item-$i";?>">

然后你会得到类似的东西..

<li class="article item-1">content</li>
<li class="article item-2">content</li>
<li class="article item-3">content</li>

然后在悬停时切换一个类到..

$(document).ready(function(){
    $('li.article').hover(function(){
        $(this).toggleClass('active-item');
    });
});

然后为您提供一个涵盖所有列表项的类,一个对显示的每个项目唯一的一个,以及一个仅在悬停时附加到元素的类。

li.article { /* CSS for all list items */ }
li.article.active-item { /* CSS for all any item active */ }
li.item-1 { /* CSS for the first item */ }
li.item-2 { /* CSS for the second item */ }
li.active-item.item-1 { /* CSS for the first item when hovered */ }
li.active-item.item-2 { /* CSS for the secpnd item when hovered */ }

注意:使您的 CSS 选择器更具体并没有什么坏处,在这些选择器前面添加一个 ID(例如,父列表 ID)将有助于确保您减少与其他竞争样式的冲突。

我希望这会有所帮助.. ;)

于 2011-02-18T19:17:05.627 回答