這四種瀏覽器分別為IE(Internet Explorer)、NS(Netscape)、Opera、FF(FireFox)。

clientHeight大家對 clientHeight 都沒有什么異 " /> 欧美一级片免费,婷婷在线综合,在线观看www成人影院

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

javascript知識點收藏

1.四種瀏覽器對 document.body 的 clientHeight、offsetHeight 和 scrollHeight 的解釋。

這四種瀏覽器分別為IE(InterNET Explorer)、NS(NETscape)、Opera、FF(FireFox)。

clientHeight
大家對 clientHeight 都沒有什么異議,都認為是內容可視區域的高度,也就是說頁面瀏覽器中可以看到內容的這個區域的高度,一般是最后一個工具條以下到狀態欄以上的這個區域,與頁面內容無關。

offsetHeight
IE、Opera 認為 offsetHeight = clientHeight + 滾動條 + 邊框。
NS、FF 認為 offsetHeight 是網頁內容實際高度,可以小于 clientHeight。

scrollHeight
IE、Opera 認為 scrollHeight 是網頁內容實際高度,可以小于 clientHeight。
NS、FF 認為 scrollHeight 是網頁內容高度,不過最小值是 clientHeight。

簡單地說
clientHeight 就是透過瀏覽器看內容的這個區域高度。
NS、FF 認為 offsetHeight 和 scrollHeight 都是網頁內容高度,只不過當網頁內容高度小于等于 clientHeight 時,scrollHeight 的值是 clientHeight,而 offsetHeight 可以小于 clientHeight。
IE、Opera 認為 offsetHeight 是可視區域 clientHeight 滾動條加邊框。scrollHeight 則是網頁內容實際高度。

同理
clientWidth、offsetWidth 和 scrollWidth 的解釋與上面相同,只是把高度換成寬度即可。

但是
FF 在不同的 DOCTYPE 中對 clientHeight 的解釋不同, xhtml 1 trasitional 中則不是如上解釋的。其它瀏覽器則不存在此問題。


2.JS取clientHeight與scrollTop
先來段數據,下表的值為document.body.clientHeight / document.documentElement.clientHeight

             IE               FF
Html       608/0          630/11096
Xhtml     10942/591    11076/630

在html/xhtml與ie/ff這4種排列組合下,取得的clientHeight幾乎沒有一樣的,可見寫一段兼容3種瀏覽器兩種頁面標準的js腳本有多頭疼。

暫時總結的判斷方法如下:
var h1 = document.body.clientHeight;
var h2 = document.documentElement.clientHeight;
var isXhtml = (h2<=h1&&h2!=0)?true:false; //判斷當前頁面的Doctype是否為Xhtml
var body = isXhtml?document.documentElement:document.body;
alert(body.clientHeight); //最終結果比較一致

安全的取到scrollTop:
document.body.scrollTop + document.documentElement.scrollTop

判斷瀏覽器的類型,這種寫法挺喜歡的:
var ua = navigator.userAgent.toLowerCase ();
var os = new Object();
os.isFirefox = ua.indexOf ("gecko") != -1;
os.isOpera = ua.indexOf ("opera") != -1;
os.isIE = !os.isOpera && ua.indexOf ("msie") != -1;


3.js取到flash對象方法匯總

IE, FF, Maxthon用document.getElementById(id)
Opera用 document.embeds(id)

var isOpera=(window.opera&&navigator.userAgent.match(/opera/gi))?true:false;

if(isOpera){
var oswf = document.embeds('ad_flipper_swf');
}else{
var oswf = document.getElementById('ad_flipper_swf');
}


4.js執行順序
1.同級的不同的代碼塊,代碼塊間的執行順序為從上到下;
2.在代碼中嵌入代碼的情況下,先執行上層代碼塊,再執行子代碼塊;代碼中嵌入代碼
是指一個文件引入另一個文件,而不是指所有的通過document.write形式打出的代碼。

JavaScript技術javascript知識點收藏,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 91在线视频免费看 | 视频一区亚洲 | 成人在线精品视频 | 小视频在线观看免费 | 91po国产在线高清福利 | 亚洲国产精品综合久久一线 | 日韩高清一区二区三区五区七区 | 国产乱人伦精品一区二区 | 精品国产一区二区三区四 | 色多多网站在线观看 | 火辣福利视频 | 9 1 视频在线 | 欧美日韩一区二区三区视频 | 久久中文网 | 欧美色欧美色 | 国产精品久久久久久亚洲小说 | 欧美精品自拍 | 亚洲资源在线观看 | 久久宗合色 | 亚洲产国偷v产偷v自拍涩爱 | 欧美日韩亚洲国产一区二区三区 | 99在线精品免费视频九九视 | 日本免费一区二区三区a区 日本免费一区二区三区看片 | 精品综合久久88色鬼首页 | 成人在线亚洲 | 亚洲综合色婷婷中文字幕 | 久久青青91费线频观青 | 深夜影院深a入口 | 日本高清www视频在线观看 | 国产一区二区精品在线观看 | 久久精品久久久 | 日本高清色片 | 国内成人精品亚洲日本语音 | 欧美在线网址 | 手机在线观看亚洲国产精品 | 一区二区手机视频 | 在线播放黄色 | 午夜激情网站 | 性福利视频 | 久久成人亚洲香蕉草草 | 碰人超人人人超人人 |