A 三位一體的頁面 網頁的結構層(Structure )由HTML 或XHTML 創建;
網頁的表現層(Presentation )由CSS 來創建;
網頁的行為層(Behavior )由Javascript 和DOM 所完成;
其實,網頁的表現層和行為層總是存在的,即使用戶沒有去定義。因為Web 浏覽器會把自身默認的樣式和事件加載到網頁的結構層上。
B 使用className 屬性
Javascript 還可以通過className 屬性靈活的更改一個標簽元素的CSS 類選擇器來實現樣式的變化。
代碼示例:
復制代碼 代碼如下:
<html>
<head>
<title>追加CSS類別</title>
<style type="text/css">
.myUL1{
color:#0000FF;
font-family:Arial;
font-weight:bold;
}
.myUL2{
text-decoration:underline;
}
</style>
<script language="javascript">
function check(){
var oMy = document.getElementsByTagName("ul")[0];
oMy.className += " myUL2"; //追加CSS類,注意" myUL2"前面的空格.
}
</script>
</head>
<body>
<ul onclick="check()" class="myUL1">
<li>HTML</li>
<li>JavaScript</li>
<li>CSS</li>
</ul>
</body>
</html>
運行時,單擊列表後,實際上<ul> 的class 屬性變為:
<ul onclick="check()" class="myUL1 myUL2">
注意:
i > 如果是直接修改className 屬性值,則是對CSS 進行替換;
ii > 但以上代碼不是將原有的CSS 樣式覆蓋,而是對現有CSS 樣式進行追加。
追加的前提是:保證追加的CSS 與原先的CSS 不重復;
經驗:
浏覽器之間顯示的差異,通常都是因為各個浏覽器本身對CSS 屬性的默認值不同所導致的。
通常的解決辦法是:程序員自己指定該值,而不讓浏覽器使用其默認值即可。