zoukankan      html  css  js  c++  java
  • 前端应该掌握的CSS实现多列等高布局

    1、引言

    我们在写页面的时候,有的时候会遇到多栏布局,每个栏目里面的内容有的时候可能不一样,这样就会导致每个栏目实际的高度也是不一样的,如果每个栏目有背景颜色的,就会导致每个栏目的底部是对不齐的,用户体验不是很好!

    实际的问题效果如下所示:

    2、需求如下

    我们要实现的效果就是不管每个栏目的实际内容多少,都要保证每个栏目是对齐的。

    3、如何解决

    HTML代码如下所示:

      <ul class="Article">
        <li class="js-equalheight">
          <p>
          一家将客户利益置于首位的经纪商,
          为客户提供专业的交易工具一家将客户利益置于首位的经纪商,
          为客户提供专业的交易工具一家将客户利益置于首位的经纪商,
          为客户提供专业的交易工具一家将客户利益置于首位的经纪商,为客户提供专业的交易工具
          </p>
        </li>
        <li class="js-equalheight">
          <p>一家将客户利益置于首位的经纪商,为客户提供专业的交易工具
          一家将客户利益置于首位的经纪商,为客户提供专业的交易工具</p>
        </li>
        <li class="js-equalheight">
          <p>一家将客户利益置于首位的经纪商</p>
        </li>
      </ul>
    

    (1)纯CSS方式解决

    CSS代码如下所示:

    .Article{
      overflow: hidden;
    }
    
    .Article>li{
      float: left;
      margin: 0 10px -9999px 0;
      padding-bottom: 9999px;
      background: #4577dc;
       200px;
      color: #fff;
    }
    
    .Article>li>p{
      padding: 10px;
    }
    

    分析说明:元素设置的padding-bottom尽可能大一些,并且需要设置一样大小的margin-bottom负值去抵消padding-bottom撑大的区域,正负一抵消,对于页面布局不会有影响。另外的话还需要设置父元素overflow:hidden把子元素多出来的色块背景隐藏掉,上述CSS解决方法没有任何兼容性问题,可以放心使用哈。

    (2)js方式解决

    js代码如下所示:

    jQuery( document ).ready(function() {
      equalheight();
    });
    
    jQuery(window).resize(function() {
      jQuery('.js-equalheight').css('height','auto');
      equalheight();
    });
    
    function equalheight() {
      var heights = jQuery(".js-equalheight").map(function() {
        return jQuery(this).height();
      }).get(),
    
      maxHeight = Math.max.apply(null, heights);
    
      jQuery(".js-equalheight").height(maxHeight);
    }
  • 相关阅读:
    用友 t6 凭证http API
    vue 解决 跳转外部地址携带根路径问题
    JavaScript之assign()——对象浅拷贝 (ES6)
    JavaScript之splice 添加或删除元素
    JavaScript之“==”和“===”
    C#——获取阶乘(递归、循环)
    C#——简单的表示两个数中的(三目运算)
    JavaScript 字符串之截取字符串 ——(substring、substr、slice)
    JavaScrpit之Json实现深拷贝
    Vue之this.$forceUpdate——强制更新数据
  • 原文地址:https://www.cnblogs.com/luoguixin/p/9138286.html
Copyright © 2011-2022 走看看