2016-04-04 8 views
1

私の要素の高さは、ユーザーの操作に応じて増加します。私はそれにラッパーdivを与え、そのdivに明示的なピクセルの高さとoverflow:autoを与えれば、それは私が望むように動作します(要素が親の高さより大きくなると、親のサイズを増加させません)。私は、ラッパーdivがページ上で利用可能なスペースと同じ大きさであることを望みますが、それを超えて拡大することはできません。それを与えることはheight:100%、それはちょうどより大きくなる。それにはheight:100vhもありません。ページに他の要素があり、サイズが大きすぎるためです。要素の高さをビューポートで使用できる高さに設定しますか?

ラッパーdivがビューポート(ページ上の他の要素でない場合はheight:100vh)には大きすぎるまで拡大できるようにします。

基本的にはheight : amount of available space in the viewportのようなものをお探ししています。

+0

あなたはこれまで持っていたhtml/cssを投稿するのに十分な長さのメンバーです。 – LGSon

+0

これは、 'max-height'を設定しました – LGSon

答えて

0

これは私がやってしまったものです:

var viewportHeight = $(window).height(); 
var offset = $('#gridWrapper').offset().top; 
$('#gridWrapper').height(viewportHeight - offset); 

私はリサイズで再び同じものを実行します。 gridWrapperは折り返しdivのIDです。

0

あなたがheight:80vhまたは類似を使用することができますあなたはこれを試すことができ、あなたの他の要素

+0

私はそれについて考えていましたが、残念ながら、一番上の要素は固定ピクセル量で、80vhのようなものは必ずしも正しいとは限りません。 – Jonah

0
function resizeElement() { 
var height = $(window).height(); 
var neededHeight = (70 * height)/100; //If you want 70% of the viewport 
neededHeight = parseInt(neededHeight) + 'px'; 
$("div").css('height',neededHeight); 
} 
$(document).ready(function() { 
resizeElement(); 
$(window).bind('resize', resizeElement); 
}); 

の高さに依存します。あなたはvarの高さでどのような価値を得るのかを確認する必要があるかもしれません。それに応じて、pxを追加することもできますし、neededHeightに追加することもできません。これは基本的に論理です。

+0

私は要素がページの高さ全体を占めることを望んでいません。 – Jonah

+0

これでパーセンテージ・カウントを行うことができます。 var neededHeight =(70 *高さ)/ 100のようなもの; neededHeight = parseInt(neededHeight)+ 'px';たとえば、ビューポートの70%を希望する場合は –

+0

あなたのニーズに合わせて上記のコードを編集しました。 –

関連する問題