2

私はポートフォリオのクラスで各画像の高さを見つけようとしています.overlay。その高さが 500 未満の場合は、id が page_categories でクラスが.entry.

これは機能しますが、ページ上のすべての画像ではなく、1 つの画像に対してのみ機能します。

<script>
  $(document).ready(function () {   
  $('img.portfolioImg').load(function() {
    var imgHeight = $('img.portfolioImg').height();
    $('.overlay').css('height', imgHeight - 40 + 'px');
    if ( $('.overlay').height() < 500 ) {
      $('#page_categories').css('display', 'none');
      $('.entry').css('display', 'none');
    }else{
    // do nothing
    }
  });
});
</script>
<div class="ct-coll-item col2 masonry-brick">
  <article>
    <img class="portfolioImg" src="_/img/13.png" />
    <div class="overlay">
      <div id="page_categories">
        <a href="#">Publication</a>, <a href="#">Typeface</a>
      </div>
      <h2><a href="#">Adam Howe Styles Men of Alaska for Port Magazine</a></h2>
      <div class="entry">
        <p>An experimental typographic project by Riccardo Sabatini, which is a typeface inspired by old mechanics technical drawings, the steampunk visual world, and modern machinery.</p>
      </div>
      <footer class="postmetadata">
        <time>July 23rd, 2012</time> / <a href="#">1 Comment</a>
      </footer>
    </div>
  </article>
</div>

これは何度も繰り返されます。すべての画像と兄弟/子供div.ct-coll-itemに適用する方法がわかりません。.each()

4

2 に答える 2

2

おそらくあなたはこれが欲しいでしょう:

$('img.portfolioImg').bind('load',function() {
    var imgHeight = $(this).height();
    var $overlay = $(this).siblings('.overlay');
    $overlay.css('height', imgHeight - 40 + 'px');
    if ( $overlay.height() < 500 ) {
        $('#page_categories',$overlay).css('display', 'none');
        //                    ^---------- selector context
        $('.entry',$overlay).css('display', 'none');
        //            ^---------- selector context
    }else{
    // do nothing
    }
});

.load()非推奨です

于 2012-07-26T10:24:21.470 に答える
1

私はあなたが変わるべきだと思う

$('img.portfolioImg').load(function() {
var imgHeight = $('img.portfolioImg').height();

$('img.portfolioImg').each(function(image) {
var imgHeight = $(this).height();

$('img.portfolioImg').height();最初の要素の高さを与えるため

于 2012-07-26T10:25:42.667 に答える