dtef9322 2014-03-11 10:07
浏览 45
已采纳

如果类存在,则给下一个div一个上边距,但用php确定边距高度

I'm trying to give the first div a top margin only if the class fixed-header exists, I've tried doing this with pure css but there were to many variables and I was losing track so I'm thinking use jquery.

Here's some simple html

<div id="page-container">
  <div id="header" class="fixed-header">header</div>
  <div>Test 2</div>
  <div>Test 3</div>
  <div>Test 4</div>
  <div>Test 5</div>
</div>

Basically, if .fixed-header does exists give the first div, in this case it's 'test2' a top margin which matches the header, if there is no 'div2' then give 'div3' a top margin and so on.

Now for the tricky part, the top margin must be determined from a php script, here's how I get the header height below.

<?php echo $header_options['header_height'] ?>

How can I do this in jquery?

Here's a basic fiddle to start me off

  • 写回答

6条回答 默认 最新

  • duan0504 2014-03-11 10:16
    关注

    If i understood you correctly, you can do that in CSS like that:

    .page-container div.fixed-header:nth-child(1) + div,
    .page-container div:not(.fixed-header):nth-child(1){
        margin-top:20px;
        // or
        margin-top: <?php echo $header_options['header_height'] ?>px;
        background:red;
    }
    

    this will give the first div after .fixed-header or the first one in .page-container (if no fixed-header exists) a margin.

    Demo

    If you want the margin be exactly the same as the height of the header without php, then yes, you'll have to resort to javascript/jquery. Something like this

    $('#page-container div.fixed-header:nth-child(1)').each(function(){
        $(this).next().css({'margin-top':$(this).height()});
    });
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决