獲取元素方法一
可以使用內置對象document上的getElementById方法來獲取頁面上設置了id屬性的元素,獲取到的是一個html對象,然后將它賦值給一個變量,比如:
<script type="text/JAVAscript"> var oDiv = document.getElementById('div1'); </script> .... <div id="div1">這是一個div元素</div>
上面的語句,如果把JavaScript寫在元素的上面,就會出錯,因為頁面上從上往下加載執行的,javascript去頁面上獲取元素div1的時候,元素div1還沒有加載,解決方法有兩種:
第一種方法:將javascript放到頁面最下邊
.... <div id="div1">這是一個div元素</div> .... <script type="text/javascript"> var oDiv = document.getElementById('div1'); </script> </body>
第二種方法:將javascript語句放到window.onload觸發的函數里面,獲取元素的語句會在頁面加載完后才執行,就不會出錯了。
<script type="text/javascript"> window.onload = function(){ var oDiv = document.getElementById('div1'); } </script> .... <div id="div1">這是一個div元素</div>
獲取元素方法二
可以使用內置對象document上的getElementsByTagName方法來獲取頁面上的某一種標簽,獲取的是一個選擇集,不是數組,但是可以用下標的方式操作選擇集里面的標簽元素。
<script type="text/javascript"> window.onload = function(){ var aLi = document.getElementsByTagName('li'); // aLi.style.backgroundColor = 'gold'; // 出錯!不能同時設置多個li alert(aLi.length); aLi[0].style.backgroundColor = 'gold'; } </script> .... <ul> <li>1</li> <li>2</li> <li>3</li> <li>4</li> <li>5</li> <li>6</li> </ul>
操作元素屬性
獲取的頁面元素,就可以對頁面元素的屬性進行操作,屬性的操作包括屬性的讀和寫。
操作屬性的方法
1、“.” 操作
2、“[ ]”操作
屬性寫法
1、html的屬性和js里面屬性寫法一樣
2、“class” 屬性寫成 “className”
3、“style” 屬性里面的屬性,有橫杠的改成駝峰式,比如:“font-size”,改成”style.fontSize”
通過“.”操作屬性:
<script type="text/javascript"> window.onload = function(){ var oInput = document.getElementById('input1'); var oA = document.getElementById('link1'); // 讀取屬性值 var sValue = oInput.value; var sType = oInput.type; var sName = oInput.name; var sLinks = oA.href; // 寫(設置)屬性 oA.style.color = 'red'; oA.style.fontSize = sValue; } </script> ...... <input type="text" name="setsize" id="input1" value="20px"> <a href="http://www.itcast.cn" id="link1">傳智播客</a>
通過“[ ]”操作屬性:
<script type="text/javascript"> window.onload = function(){ var oInput1 = document.getElementById('input1'); var oInput2 = document.getElementById('input2'); var oA = document.getElementById('link1'); // 讀取屬性 var sVal1 = oInput1.value; var sVal2 = oInput2.value; // 寫(設置)屬性 // oA.style.val1 = val2; 沒反應 oA.style[sVal1] = sVal2; } </script> ...... <input type="text" name="setattr" id="input1" value="fontSize"> <input type="text" name="setnum" id="input2" value="30px"> <a href="http://www.itcast.cn" id="link1">傳智播客</a>
innerHTML
innerHTML可以讀取或者寫入標簽包裹的內容
<script type="text/javascript"> window.onload = function(){ var oDiv = document.getElementById('div1'); //讀取 var sTxt = oDiv.innerHTML; alert(sTxt); //寫入 oDiv.innerHTML = '<a href="http://www.itcast.cn">傳智播客<a/>'; } </script> ...... <div id="div1">這是一個div元素</div>