KANTENNA.COM

Solarized

HOME > WEBプログラム覚書 > Divの高さを合わせるスクリプト

Divの高さを合わせるスクリプト

tableでは簡単な高さあわせだが、CSSレイアウトの場合なかなか難しく背景などが途中で切れてしまうことが多々ある。

もちろん大枠で囲んでやればいいわけだが、Javascriptを利用して高さそろえるのもありかも。

Javascriptサンプル

指定したIDで一番高いものにその他の高さを合わせます。

Javascript
  1.  <script language="javascript" type="text/javascript">
  2.  //<![CDATA
  3.  
  4.   //左右コンテンツの高さあわせ(高いほうに)
  5.   window.onload = function(){
  6.  
  7.   //高さ合わせるIDを指定
  8.   var id = new Array("jsLeft", "jsCenter", "jsRight");
  9.   var idHeight = new Array();
  10.  
  11.   //指定IDの高さを取得
  12.   for(i=0; i<id.length; i++){
  13.   idHeight[i] = document.getElementById(id[i]).offsetHeight;
  14.   }
  15.  
  16.   //配列を昇順でソート
  17.   idHeight.sort(
  18.   function Func(a, b){//ソートのための比較関数
  19.   return (b - a);
  20.   }
  21.   );
  22.  
  23.   //一番高いのに合わせる
  24.   for(i=0; i<id.length; i++){
  25.   document.getElementById(id[i]).style.height = idHeight[0] + "px";
  26.   }
  27.  
  28.   }
  29.  //]]>
  30.  </script>
HTML
  1.  <div id="jsHeight01">
  2.  
  3.   <div id="jsLeft">
  4.   <h5>Javascript</h5>
  5.   <p>Javascriptはクライアントサイドで動作するプログラムです。</p>
  6.   <p>柔軟な言語のせいかいろいろな書き方があってわけわかりません。</p>
  7.   </div>
  8.  
  9.   <div id="jsCenter">
  10.   <h5>PHP</h5>
  11.   <p>PHPはサーバサイドで動作するプログラムです。</p>
  12.   <p>
  13.   PHP5は本格的なオブジェクト指向言語となり、PHP4のサポートも2007年いっぱいで終了のようですので<br />
  14.   PHP5に乗り換えたいのですが現在レンタルサーバはPHP5に対応しているところはあまりないので躊躇してしまいます。
  15.   </p>
  16.   </div>
  17.  
  18.   <div id="jsRight">
  19.   <h5>MySQL</h5>
  20.   <p>MySQLはデータベースです。</p>
  21.   </div>
  22.  </div>

CSSサンプル

CSS
  1.  #jsLeft, #jsCenter, #jsRight {
  2.   float: left;
  3.   width: 200px;
  4.   padding: 5px;
  5.  }
  6.  #jsLeft {
  7.   background-color: #CCCCCC;
  8.  }
  9.  #jsCenter {
  10.   background-color: #000000;
  11.  }
  12.  #jsRight {
  13.   background-color: #993300;
  14.  }

実行結果

Javascript

Javascriptはクライアントサイドで動作するプログラムです。

柔軟な言語のせいかいろいろな書き方があってわけわかりません。

PHP

PHPはサーバサイドで動作するプログラムです。

PHP5は本格的なオブジェクト指向言語となり、PHP4のサポートも2007年いっぱいで終了のようですので
PHP5に乗り換えたいのですが現在レンタルサーバはPHP5に対応しているところはあまりないので躊躇してしまいます。

MySQL

MySQLはデータベースです。



IE7、Mac IE5.5、Firefox2.0.0.8、Netscape7.1で動作確認。問題はsafariで動かないこと(爆
とりあえずプロトタイプということで近いうちになんとか原因突き止めたいところですが・・・

どーもsortあたりが怪しいっぽい・・・

パーフェクトJavaScript (PERFECT SERIES 4)
作者:浜辺 将太 | 価格:¥ 3,360

トラックバック(1)

2009年1月29日 17:00

Divの高さを合わせるスクリプト(safari対応版)WEBプログラム覚書

Divの高さを合わせるスクリプト(safari対応版)続きを読む

コメント

コメントする
Name
Email Address
URL
TIME LINE
2012
02.03

[jQuery]closest()とparents()

今から16年前Netscapeブラウザのソースコードの公開方法の会議の中で、初めてオープンソースという言葉が使われた今日、 みなさんいかがお過ごしでしょうか。

今回の投稿はそれとは関係のないjQueryのparents()とclosest()が 似てたので何が違うのか試した時のメモです。

2012
02.01

[jQuery Mobile]初期化イベントメモ

jQuery Mobileは読み込まれてから

mobileinit -> pagebeforecreate -> pagecreate -> pageinit

の順番でイベントが発生する。

2012
02.01

[WordPress]管理画面のフッタのフィルタとアクション。

時間も時間なので、あまり使用頻度の高くない微妙なネタを。

会員制サイトなどで不特定多数の人にログインさせる場合、フッタのバージョン情報は隠しておきたかったり、 こじゃれたメッセージを表示したいときとか使うアクションとフィルタ。

2012
01.28

[WordPress] ブログの情報を取得する方法とノーキャッシュ疑惑

ブログのget_bloginfo()で取れないデータが必要な場合に使うもの。

2012
01.26

[jQuery Mobile]ダイアログ

jQuery Mobileにおけるダイアログの扱いはウインドウではなくページ。 なので通常のページと同様に扱える。ダイアログウインドウを出す。じゃなくダイアログページに遷移する。的な。

2012
01.25

[Ubuntu11.10]Ubuntuのインストール後の設定

インストール完了後の環境構築。PC起動時いちいちBIOSからブートドライブ選んで ブートするのかと思ってたら起動時にOS選択画面が出てくる。

すばらしいですね。

2012
01.24
2012
01.23

MinGW+Mintty+Git

MinGW+Mintty+Gitをやろうとして失敗に終わった。このエントリーには収穫できるものはありません。

2012
01.21

[PHP]共有サーバーユーザーのためのPEARインストール方法

共有サーバーでは自由にPEARのパッケージがインストールできないので、 プロジェクトローカルに設置することになりますが、以前httpベースのものを使ってみたんですけど、 やたら重くて使い物にならなかったので、僕は普通にFTPでアップするようにしてます。

ってことでプロジェクトローカルへのPEARのインストール方法。