องค์ประกอบที่มีความสูงสูงสุดจากชุดองค์ประกอบ


85

ฉันมีชุดของdivองค์ประกอบ ในjQueryฉันต้องการจะหาdivค่าความสูงสูงสุดและความสูงของมันdivได้ด้วย ตัวอย่างเช่น:

<div>
    <div class="panel">
      Line 1
      Line 2
    </div>
    <div class="panel">
      Line 1<br/>
      Line 2<br/>
      Line 3<br/>
      Line 4<br/>
    </div>
    <div class="panel">
      Line 1
    </div>
    <div class="panel">
      Line 1
      Line 2
    </div>
</div>

จากการดูด้านบนเราจะรู้ว่าเส้นที่ 2 div(มี 4 เส้น) มีความสูงสูงสุดของทั้งหมด ฉันจะหาข้อมูลนี้ได้อย่างไร ใครช่วยได้บ้าง

จนถึงตอนนี้ฉันได้ลอง:

$("div.panel").height()divซึ่งผลตอบแทนสูงของที่ 1

คำตอบ:


213

ใช้.map()และMath.max.

var maxHeight = Math.max.apply(null, $("div.panel").map(function ()
{
    return $(this).height();
}).get());

หากอ่านแล้วสับสนสิ่งนี้อาจชัดเจนกว่า:

var heights = $("div.panel").map(function ()
    {
        return $(this).height();
    }).get();

maxHeight = Math.max.apply(null, heights);

1
สิ่งนี้พบความสูงสูงสุด แต่ไม่ได้อ้างอิงถึงองค์ประกอบจริง
Vincent Ramdhanie

คุณถูก; ฉันไม่ชัดเจนว่า OP ต้องการองค์ประกอบเช่นกัน คำตอบของคุณใช้ได้ผลในกรณีนั้น
Matt Ball

3
@MattBall ทำไมฟังก์ชัน get ฉันขอได้ไหม มันทำอะไรและมีจุดประสงค์อะไร?
chodorowicz

2
@chodorowicz ดีใจที่คุณถาม ดูคำตอบนี้ภายใต้หัวข้อที่สอง
Matt Ball

1
@MattBall ขอบคุณ ดังนั้น jQuery .map จะส่งคืนวัตถุที่เหมือนอาร์เรย์และรับ. get เปลี่ยนเป็นอาร์เรย์ แต่ดูเหมือนว่า Math.max จะทำงานได้ง่ายกับทั้งสองประเภทนี้ (ทดสอบในคอนโซล Chrome) ดังนั้นในกรณีนี้ดูเหมือนว่า. get ไม่จำเป็น หรือว่าฉันผิด?
chodorowicz

20

html ที่คุณโพสต์ควรใช้บางส่วน<br>เพื่อให้มี div ที่มีความสูงต่างกัน แบบนี้:

<div>
    <div class="panel">
      Line 1<br>
      Line 2
    </div>
    <div class="panel">
      Line 1<br>
      Line 2<br>
      Line 3<br>
      Line 4
    </div>
    <div class="panel">
      Line 1
    </div>
    <div class="panel">
      Line 1<br>
      Line 2
    </div>
</div>

นอกเหนือจากนั้นหากคุณต้องการอ้างอิงถึง div ที่มีความสูงสูงสุดคุณสามารถทำได้:

var highest = null;
var hi = 0;
$(".panel").each(function(){
  var h = $(this).height();
  if(h > hi){
     hi = h;
     highest = $(this);  
  }    
});
//highest now contains the div with the highest so lets highlight it
highest.css("background-color", "red");

ระวังตัวนี้ด้วยถ้าคุณไม่ได้ใช้วิธี jQuery ข้างใน (เช่น.heightในกรณีนี้) คุณต้องยกเลิกการอ้างอิงเช่น: $ (this) [0] .scrollHeight; `
rogerdpack

5

หากคุณต้องการใช้ซ้ำในหลาย ๆ ที่:

var maxHeight = function(elems){
    return Math.max.apply(null, elems.map(function ()
    {
        return $(this).height();
    }).get());
}

จากนั้นคุณสามารถใช้:

maxHeight($("some selector"));

1

function startListHeight($tag) {
  
    function setHeight(s) {
        var max = 0;
        s.each(function() {
            var h = $(this).height();
            max = Math.max(max, h);
        }).height('').height(max);
    }
  
    $(window).on('ready load resize', setHeight($tag));
}

jQuery(function($) {
    $('#list-lines').each(function() {
        startListHeight($('li', this));
    });
});
#list-lines {
    margin: 0;
    padding: 0;
}

#list-lines li {
    float: left;
    display: table;
    width: 33.3334%;
    list-style-type: none;
}

#list-lines li img {
    width: 100%;
    height: auto;
}

#list-lines::after {
    content: "";
    display: block;
    clear: both;
    overflow: hidden;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>

<ul id="list-lines">
    <li>
        <img src="http://img2.vetton.ru//upl/1000/346/138/vetton_ru_sddu7-2560x1600.jpg" alt="" />
        <br /> Line 1
        <br /> Line 2
    </li>
    <li>
        <img src="http://img2.vetton.ru//upl/1000/346/138/vetton_ru_mixwall66-2560x1600.jpg" alt="" />
        <br /> Line 1
        <br /> Line 2
        <br /> Line 3
        <br /> Line 4
    </li>
    <li>
        <img src="http://img2.vetton.ru//upl/1000/346/138/vetton_ru_sddu7-2560x1600.jpg" alt="" />
        <br /> Line 1
    </li>
    <li>
        <img src="http://img2.vetton.ru//upl/1000/346/138/vetton_ru_mixwall66-2560x1600.jpg" alt="" />
        <br /> Line 1
        <br /> Line 2
    </li>
</ul>


1

ul, li {
  list-style: none;
  margin: 0;
  padding: 0;
}

ul {
  display: flex;
  flex-wrap: wrap;
}

ul li {
  width: calc(100% / 3);
}

img {
  width: 100%;
  height: auto;
}
<ul>
  <li>
    <img src="http://img2.vetton.ru//upl/1000/346/138/vetton_ru_sddu7-2560x1600.jpg" alt="">
    <br> Line 1
    <br> Line 2
  </li>
  <li>
    <img src="http://img2.vetton.ru//upl/1000/346/138/vetton_ru_mixwall66-2560x1600.jpg" alt="">
    <br> Line 1
    <br> Line 2
    <br> Line 3
    <br> Line 4
  </li>
  <li>
    <img src="http://img2.vetton.ru//upl/1000/346/138/vetton_ru_sddu7-2560x1600.jpg" alt="">
    <br> Line 1
  </li>
  <li>
    <img src="http://img2.vetton.ru//upl/1000/346/138/vetton_ru_mixwall66-2560x1600.jpg" alt="">
    <br> Line 1
    <br> Line 2
  </li>
</ul>



0

หากคุณสนใจที่จะเรียงลำดับทั้งหมดใน JavaScript มาตรฐานหรือไม่ใช้ forEach ():

var panels = document.querySelectorAll("div.panel");

// You'll need to slice the node_list before using .map()
var heights = Array.prototype.slice.call(panels).map(function (panel) {
    // return an array to hold the item and its value
    return [panel, panel.offsetHeight];
}),

// Returns a sorted array
var sortedHeights = heights.sort(function(a, b) { return a[1] > b[1]});

0

วิธีที่ง่ายและชัดเจนที่สุดที่ฉันพูดคือ:

var maxHeight = 0, maxHeightElement = null;
$('.panel').each(function(){
   if ($(this).height() > maxHeight) {
       maxHeight = $(this).height();
       maxHeightElement = $(this);
   }
});

0

สิ่งนี้อาจเป็นประโยชน์ไม่ทางใดก็ทางหนึ่ง แก้ไขโค้ดบางส่วนจาก @diogo

$(window).on('load',function(){

// get the maxHeight using innerHeight() function
  var maxHeight = Math.max.apply(null, $("div.panel").map(function ()                                                        {
    return $(this).innerHeight();
  }).get());
  
// Set the height to all .panel elements
  $("div.panel").height( maxHeight );
  
});
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.