Landscape トップページ | < 前の日 2003-08-28 2003-08-29 次の日 2003-08-30 >

Landscape - エンジニアのメモ 2003-08-29

JavaScript で id や name 属性でオブジェクトにアクセスする


* JavaScript で id や name 属性でオブジェクトにアクセスする

この記事の直リンクURL: Permlink | この記事が属するカテゴリ: [JavaScript]

<a href="/" id="backlink" name="backlink">&lt;戻る</a>
上記 a 要素があるとする。スクリプトから href 属性をコントロールしたいので、
id と name を明示的に指定して名前付けをしてある。
しかし、例によって UserAgent によって、名前でのアクセスの仕方が異なる。

- パターン

alert(window.document.links['backlink'].href);
alert(document.links['backlink'].href);
alert(links.['backlink'].href);
alert(backlink.href);

調査結果は省略するが、Mozilla と IE でそれぞれどの表記にも対応している訳ではなく、両方で使用できるパターンは無かった。

複数のブラウザに対応させる良い方法は無いだろうか?
Google で javascript オブジェクト 有無 判定を検索すると、もじら組のページがヒットした。

ブラウザ判別とオブジェクト検出 - Web標準普及プロジェクト
http://www.mozilla.gr.jp/standards/webtips1004.html

オブジェクトが存在するかどうかを直接チェックする方法だ。汎用的な手法ということで、このコードを使うことにした。

ブラウザ判別に代わる方法として、実際に使いたいオブジェクトの有無を判定するオブジェクト検出という方法があります。

function toggleLayer2(id){
  if (document.getElementById) {
      if (document.getElementById(id).style.visibility == "hidden") {
        document.getElementById(id).style.visibility = "visible";
      } else {
        document.getElementById(id).style.visibility = "hidden";
      }
  } else if (document.all) {
    if (document.all(id).style.visibility == "hidden") {
      document.all(id).style.visibility = "visible";
    } else {
      document.all(id).style.visibility = "hidden";
    }
  } else if (document.layers) {
    if (document.layers[id].visibility == "hide") {
      document.layers[id].visibility = "show";
    } else {
      document.layers[id].visibility = "hide";
    }
  }
}


すべての記事の見出し (全1029件)
全カテゴリの一覧と記事の数
カテゴリごとに記事をまとめ読みできます。記事の表題だけを見たい場合は、すべての記事の見出し (カテゴリ別表示) へ。

直近30日分の記事
2007-04-23 (Mon)
2007-03-07 (Wed)
2007-02-27 (Tue)
2007-01-17 (Wed)
2007-01-15 (Mon)
2007-01-14 (Sun)
2007-01-08 (Mon)
2006-12-01 (Fri)
2006-11-22 (Wed)
2006-11-20 (Mon)
2006-11-19 (Sun)
2006-09-30 (Sat)
2006-08-29 (Tue)
2006-08-04 (Fri)
2006-07-27 (Thu)
2006-07-23 (Sun)
2006-07-17 (Mon)
2006-07-10 (Mon)
2006-07-06 (Thu)
2006-07-03 (Mon)
2006-06-29 (Thu)
2006-06-28 (Wed)
2006-06-27 (Tue)
2006-06-25 (Sun)
2006-06-19 (Mon)
2006-06-18 (Sun)
2006-06-15 (Thu)
2006-06-11 (Sun)
2006-06-01 (Thu)
2006-05-30 (Tue)
プロファイル
斎藤 宏明。エンジニアです。宇都宮市に住んでいます。
リンク
RSS
スポンサードリンク
Powered by
さくらインターネット

© 斎藤 宏明 Saito Hiroaki Gmail Address
Landscape - エンジニアのメモ http://sonic64.com/
Landscape はランドスケープと読みます。
ひらがなだと らんどすけーぷ です。