Saltar para: Post [1], Comentários [2], Pesquisa e Arquivos [3]

SAPO Blogs

Como pôr a barra lateral com a mesma altura da área de posts?

por Hugo, em 02.01.07

Temos recebido alguns pedidos de ajuda sobre como pôr as barras laterais do blog com  a mesma altura da área dos posts. Neste post vou mostrar um script que vai responder a estes  pedidos:

 
 
Template
2 colunas
 
Template
3 colunas
 

 

 

 

 
Antes Depois
 
Antes
 
Depois
 

 
Esta alteração não pode ser feita só com css porque a altura da área de post está dependente do conteúdo dos posts. A solução é escrever um script que vê a altura máxima da área de posts para depois alterar a altura da  barra lateral.

<script type="text/javascript">
    matchHeight=function(){
        var divs,contDivs,maxHeight,divHeight,d;
        var div_extra,div_extrab,div_posts;

        /* <div> a redimensionar */
        div_extras=document.getElementById('extras');
        div_extrasb=document.getElementById('extrasB');
        div_posts=document.getElementById('posts');
        divs=[div_extras,div_extrasb,div_posts];
        contDivs=[];

        /* altura maxima */
        maxHeight=0;

        /* procura altura maxima dos <div> */
        for(var i=0;i<divs.length;i++){
            d=divs[i];
            if (d) {
                contDivs[contDivs.length]=d;
                if(d.offsetHeight){
                    divHeight=d.offsetHeight;
                }
                else if(d.style.pixelHeight){
                    divHeight=d.style.pixelHeight;
                }
                maxHeight=Math.max(maxHeight,divHeight);
            }
        }

        /* redimensiona os <div> */
        for(var i=0;i<contDivs.length;i++){
            contDivs[i].style.height=maxHeight+"px";
        }
    }

/* Executa o script */ 
window.onload=function(){
    if(document.getElementById){
        matchHeight();
    }
}
</script>


Para pôr o script a funcionar:
  1. Copiar o código do script para um componente (Personalização intermédia > Componentes).
  2. Activar o componente na barra lateral (Personalização intermédia > Posições).
  3. Gravar as alterações.
O script funciona com todos os templates que tenham uma ou duas barras laterais.

Este script foi adaptado de um artigo publicado no site www.devarticles.com. Aqui podem encontrar uma explicação mais detalhada do funcionamento do script.
 

38 comentários

  • Imagem de perfil

    De Mamã Alice a 30.08.2007 às 12:22

    OLÁ OUTRA VEZ. JA PERCEBI QUAL O PROBLEMA, AO FAZER COPY DO CODIGO AQUI EM CIMA, QUANDO COLAVA NO COMPONENTE FICAVA TUDO SEGUIDO. AO LER OUTROS COMENTARIOS ACIMA VI Q ESSE TB ERA UM DOS PROBLEMAS DE OUTRO BLOGUISTA.

    SEJA COMO FOR, JÁ ESTÁ!!!!! MUITO OBRIGADO PELA VOSSA AJUDA.

    JÁ AGORA, COMO POSSO REDUZIR UM POUCO O ESPAÇO "MORTO" NO CABEÇALHO? DE MANEIRA A QUE O TIULO DO BLOG "PRINCIPE DUARTE FIQUE BEM NA MESMA.

    OBRIGADA UMA VEZ MAIS

    ALICE


    http://titicad.blogs.sapo.pt/
  • Imagem de perfil

    De jonasnuts a 30.08.2007 às 13:18

    Ó Alice, sabia que quando escreve em maiúsculas, é sinónimo de que está a gritar? :)

    Um dia destes faço um post sobre netiquette, mas entretanto, use as minúsculas, que nós conseguimos ouvir lindamente :)
  • Imagem de perfil

    De Mamã Alice a 30.08.2007 às 13:26

    Talvez nao escreva... assim nao incomodo tanto ao ponto de se dar ao trabalho de escrever um comentario so porque eu escrevi em maiusculas....

    Sabe, nem todos podemos saber de etiqueta... Eu sou do povo....

    Alice
  • Imagem de perfil

    De jonasnuts a 30.08.2007 às 15:43

    Não incomoda nada, e não foi trabalho nenhum, e penso que o tom do comentário era cordial e pedagógico.

    Sabe, eu também sou do povo :)
  • Imagem de perfil

    De Hugo a 30.08.2007 às 19:21

    Para reduzir o espaço do cabeçalho é preciso fazer as seguintes alterações na css:
    #header {width:400px; /*height:120px;*/ margin-bottom:10px; padding-left:0px; }
    #header .title { font-size:28px; font-weight:bold; color:#ffffff; /*padding-top:90px;*/ width:724px; text-align:left;}
  • Comentar post

    Pág. 1/2