Jquery通过读取html内容拆分列

时间:2016-01-09 07:18:01

标签: jquery split rows

我正在处理一个响应式页面,其中div从后端以下面的方式生成。我已经使用jquery重新安排这些div用于不同的屏幕,如下所述。

<div class="tiles">
  <div class="col first" style="width: 25%;">
    <div class="tile" data-index="1"></div>
    <div class="tile" data-index="5"></div>
    <div class="tile" data-index="9"></div>
  </div>
  <div class="col" style="width: 25%;">
    <div class="tile" data-index="2"></div>
    <div class="tile" data-index="6"></div>
    <div class="tile" data-index="10"></div>
  </div>
  <div class="col" style="width: 25%;">
    <div class="tile" data-index="3"></div>
    <div class="tile" data-index="7"></div>
    <div class="tile" data-index="11"></div>
  </div>
  <div class="col last" style="width: 25%;">
    <div class="tile" data-index="4"></div>
    <div class="tile" data-index="8"></div>
    <div class="tile" data-index="12"></div>
  </div>
</div>

我必须阅读html数据并在下面的场景中按顺序在响应中进行排序。 480:2, 1024:3, 1280:4, 1680:5

让我们说480px 2列,

<div class="tiles">
  <div class="col first" style="width: 50%;">
    <div class="tile" data-index="1"></div>
    <div class="tile" data-index="3"></div>
    <div class="tile" data-index="5"></div>
    <div class="tile" data-index="7"></div>
    <div class="tile" data-index="9"></div>
    <div class="tile" data-index="11"></div>
  </div>
  <div class="col" style="width: 50%;">
    <div class="tile" data-index="2"></div>
    <div class="tile" data-index="4"></div>
    <div class="tile" data-index="6"></div>
    <div class="tile" data-index="8"></div>
    <div class="tile" data-index="10"></div>
    <div class="tile" data-index="12"></div>
  </div>
</div>

让我们说1024px,3列..与其他分辨率相似

<div class="tiles">
  <div class="col first" style="width: 33.333%;">
    <div class="tile" data-index="1"></div>
    <div class="tile" data-index="4"></div>
    <div class="tile" data-index="7"></div>
    <div class="tile" data-index="10"></div>
    <div class="tile" data-index="13"></div>
    <div class="tile" data-index="16"></div>
  </div>
  <div class="col" style="width: 33.333%;">
    <div class="tile" data-index="2"></div>
    <div class="tile" data-index="5"></div>
    <div class="tile" data-index="8"></div>
    <div class="tile" data-index="11"></div>
    <div class="tile" data-index="14"></div>
    <div class="tile" data-index="17"></div>
  </div>
  <div class="col last" style="width: 33.333%;">
    <div class="tile" data-index="3"></div>
    <div class="tile" data-index="6"></div>
    <div class="tile" data-index="9"></div>
    <div class="tile" data-index="12"></div>
    <div class="tile" data-index="15"></div>
    <div class="tile" data-index="18"></div>
  </div>
</div>

1 个答案:

答案 0 :(得分:1)

试试这个

var contentslength=12;
function pageresponsive(parentclass,colcount){
$(parentclass).empty();
$(parentclass).append("<div class='tiles "+colcount+"-column'></div>");
    var collength=colcount;
    var colarray=[];
    var a=1;
    var c=1;
    for(var i=1;i<=contentslength;i++){

      if(a>collength){
        a=1;
      }
      if(a<=collength){
          if(colarray[a-1]!=undefined){
           colarray[a-1]= colarray[a-1]+"<div class='tile' data-index='"+c+"'>ddd</div>";
           }
           else{
             colarray[a-1]="<div class='tile' data-index='"+c+"'>ddd</div>";
           }
      }
      a=a+1;
      c=c+1;
    }
    var newdataarray=[];

    for(var i=0;i<colarray.length;i++){
      var thisclass=(i==0) ? "first" : ""
      var allclasses="col col-"+(i+1)+" "+thisclass;
      var thiswidth=(100/collength)+"%"
      newdataarray.push("<div class='"+allclasses+"' style='width:"+thiswidth+"'>"+colarray[i]+"</div>")

    }
    $("."+collength+"-column").html(newdataarray.join(""));



}

function addcols(){
      var windowwidth=$(window).width();
      if(windowwidth<480){
          pageresponsive(".row",2)
      }
      else if(windowwidth>=480 && windowwidth<1024){
          pageresponsive(".row",3)
      }
      else if(windowwidth>=1024 && windowwidth<1280){
          pageresponsive(".row",4)
      }
      else{
        pageresponsive(".row",5)
      }

}
addcols();
//for window resize
$(window).resize(function(){
addcols();
});
body,body *{
 box-sizing:border-box;
}

.tiles{
  width:100%;
  float:left;
  margin-bottom:10px;
  padding:20px;
 
}

.col{
  float:left;
   padding:20px;
  background:green;
}
.col-2{
  background:pink;
}
.col-3{
  background:red;
}
.col-4{
  background:violet;
}
.col-5{
  background:purple;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<div class="row">

</div>

JS小提琴演示:https://jsfiddle.net/geogeorge/6sg3jdok/4/show

以不同的屏幕宽度检查此演示