- ベストアンサー
グローバル変数とgetElementByIdの処理速度比較
- グローバル変数を使用して一時的に値を保持して計算する方法と、getElementByIdで要素を取得して計算する方法の処理速度を比較します。
- 質問文章では、2つのSELECT要素の選択値を取得して計算する処理を想定しています。
- グローバル変数を使用する方法では、パンと水の価格を保持して合計価格を計算し、アラートで表示します。
- みんなの回答 (6)
- 専門家の回答
質問者が選んだベストアンサー
ブラウザによりますが、少なくともIE6では getElementById は ページ内のid数に ほぼ正確に速度が反比例します。キャッシュも効きません。 id がページ内に数千個あると、下記のハッシュに比べ getElementById の速度は 数十分の 1 になります。 ページに id がたくさんある場合で、getElementById を使いたいなら、 下記ハッシュを使うことをお勧めします。 var idHash = {}; var all_Nodes = document.getElementsByTagName('*'); var node_count = all_Nodes.length; for (var i = 0; i < node_count; i++) { var node_ref = all_Nodes[i]; var node_id = node_ref.id; if (node_id) { idHash[node_id] = node_ref; } } としておいて idhash[XXXXXXXX] とアクセス。これだけ。
その他の回答 (5)
- think49
- ベストアンサー率59% (285/482)
質問文の2つ目は getElementById のプロパティアクセス演算子が働くので、1つ目のほうが若干速いと思います。 最速を求めるなら泥臭いですが、関数を使わない方向に。プロパティアクセス演算子の使用回数を極限まで減らしてします。 http://jsfiddle.net/HNCGE/ ところでこれ、Number型に型変換していないのは期待通りでしょうか? 質問文では型変換していなかったのでそれに追従しましたが、必要なら Number() を通してください。 http://jsfiddle.net/HNCGE/1/ --- 汎用性を重視するなら、#3 さんの方法を推奨。 this.value を使わず、this.form.elements を通すのでプロパティアクセスの回数は増えますが、HTMLはすっきりします。 速度と汎用性、どちらを重視するかは好みの問題だと思います。 バランス感覚のようなもので人それぞれ違います。 個人的には拡張性も考えて http://jsfiddle.net/HNCGE/2/ のようにするかな…。 for-in にするかは迷いどころですが、目的によってコードも変わってきそうです。
- dscripty
- ベストアンサー率51% (166/325)
[ANo.2] を撤回して、[ANo.3] さんに一票。 質問内に form 要素が書かれていなくて、回答に、含めるかどうか迷ったけど、やっぱり form 要素を含めて、function calc() を記述したほうがきれいに書けるね。
- Chaire
- ベストアンサー率60% (79/130)
<form action="#"> <p> <select name="Food" onchange="calc(this);"> <option value="1">パン</option> </select> <select name="Drink" onchange="calc(this);"> <option value="1">水</option> </select> </p> </form> var Price = [, 100]; function calc(select){ var controls = select.form.elements; var food = Price[controls['Food'].value]; var drink = Price[controls['Drink'].value]; var totalPrice = food + drink; alert(totalPrice); } ・一般に JS のグローバル変数は遅い。 ・一般に JS の関数呼び出しは遅い。 ・一般に JS のプロパティアクセスは遅い。 ・form 内の name は、その form 内に限定されます(ID をまき散らさない)。 ・フォーム部品は、自身が属する form を参照できます。 ・form は、自分に属する全フォーム部品を elements に格納しています。 値の妥当性はチェックしていませんのであしからず。
- dscripty
- ベストアンサー率51% (166/325)
2つのハイブリッドを薦めてみる。 重視したのは、2点。 * 使う必要のないグローバル変数を使わない。 * function calc() は、要素の値を気にしない。 <SELECT id='Food' onchange='calc(this.value,document.getElementById('Drink').value);'> <OPTION value=1>パン</OPTION> ... </SELECT> <SELECT id='Drink' onchange='calc(document.getElementById('Food').value,this.value);'> <OPTION value=1>水</OPTION> ... </SELECT> function calc(food,drink){ totalPrice = Price[food]+Price[drink]; alert(totalPrice); } ちなみに、Food と Drink が同じ配列 Price[] から値段をとってるから、 実際には、↓かな? totalPrice = FoodPrice[food]+DrinkPrice[drink];
id に関してはDOM 構文上でHashMap にキャッシュされてると思われるので、さほど速度差は無いと思われます。 が・・・これは最近のブラウザの実装について言える希望的観測なので、正確にはループさせて計測してみては? でもまぁJQuery でやってる事よりははるかにシンプルな記述ですし、実用速度面では問題にならないでしょう?