天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

腳本控制自適應高度的縮短問題

function vvheight() {
       var sideleft=document.getElementById("content-left").scrollHeight;
       var sideright=document.getElementById("content-right").scrollHeight;
       layoutHeight=Math.max(sideleft,sideright);
       document.getElementById("content-left").style.height=layoutHeight+"px";
       document.getElementById("content-right").style.height=layoutHeight+"px";
}

我想用腳本來控制自適應高度,我用上面的代碼控制了左列和右列的自適應高度。
可是有的頁面因為內容多被撐得挺長,有的頁面內容少,用上面的代碼不能縮短了!
我就是想在訪問內容少的時候,內容還能再縮回來,代碼應該怎么寫呢?謝謝了!
復制代碼 代碼如下:
function vvheight() {
    var CL=document.getElementById("content-left");
    var CR=document.getElementById("content-right");
    while(parseInt(CL.scrollHeight)==parseInt(CL.style.height)){CL.style.height=parseInt(CL.style.height)-30+"px"}
    var sideleft=CL.scrollHeight;
    while(parseInt(CR.scrollHeight)==parseInt(CR.style.height)){CR.style.height=parseInt(CR.style.height)-30+"px"}
    var sideright=CR.scrollHeight;
    layoutHeight=Math.max(sideleft,sideright);
    CL.style.height=layoutHeight+"px";
    CR.style.height=layoutHeight+"px";
}

解答:
在IE和Opera里,DIV的style.overflowY的默認值是"auto",上面的代碼不會有問題。

在Firefox和Safari里,DIV的style.overflowY的默認值是""(相當于"hidden"),所以你直接用上面代碼的話,會出錯。需要人為調整style.overflowY="auto"。

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
下面這個算法略有不同,你看哪一個效果更好(變化的瞬間人眼睛感覺到的閃爍更?。??

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
就是這幾行代碼:

復制代碼 代碼如下:
    while(CL.scrollHeight==CL.clientHeight){CL.style.height=CL.clientHeight-30+"px"} 
    var sideleft=CL.scrollHeight; 
    while(CR.scrollHeight==CR.clientHeight){CR.style.height=CR.clientHeight-30+"px"}

沒有太多時間,就先隨便講一講吧。如果感興趣的人多,以后我可以開一些這樣的專題,或者寫到書里去。

元素的scrollHeight屬性是微軟在IE中首創的DHTML屬性,并非W3C規范或技術推薦標準的內容,但是現在幾乎所有的瀏覽器都在支持這個屬性(這是因為W3C標準中并沒有相應的替代方案――因此我通常不提“標準”二字,而總是說“兼容、可用”)。scrollHeight是元素在內部不出現縱向滾動條的情況下在頁面上顯示時將占據的高度(像素數)。
[attach]64076[/attach]

clientHeight也不是W3C規范的東西(事實上,很多有用的東西都與“標準”無關,但它們是事實上的標準)。clientHeight是元素在頁面中顯示時實際占據的高度(像素數)。
[attach]64077[/attach]

如果使元素內部不出現縱向滾動條(給元素足夠多的空間,令其可以完整顯示;或者將其縱向滾動條禁用,也就是將style.overflowY設為"hidden"),則scrollHeight==clientHeight。

在滾動條出現時,clientHeight < scrollHeight,元素未能在頁面上完整顯示,若要令其完整顯示,則至少需要scrollHeight像素高度的空間。

也就是,元素內部出現縱向滾動條時,scrollHeight就是令元素得以完整顯示的最小高度。

在上面第一個例子中,我不斷縮短DIV的高度(每次縮短30像素),直到DIV內部滾動條出現,取此時的scrollHeight值。

在第二個例子中,我直接把DIV高度設為1像素,迫使其內部出現滾動條,取scrollHeight值。

在我的顯示器上,兩個例子沒有明顯的差別。你可以把顯示器的刷新頻率調到最低,看看哪一種方式在變化的瞬間閃爍更小,擇優用之。

JavaScript技術腳本控制自適應高度的縮短問題,轉載需保留來源!

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

主站蜘蛛池模板: 广西美女色炮150p图 | 蜜桃婷婷狠狠久久综合9色 蜜桃视频一区二区 | 牢记永久免费网址 | 国产全部视频列表支持手机 | 香蕉久久夜色精品国产小说 | 超碰在线公开视频 | 儿子好妈妈的HD3中字抢劫 | 十九禁啊啪射视频在线观看 | 中文字幕在线免费视频 | 99在线国产视频 | 乳巨揉みま痴汉电车中文字幕动漫 | 国产美女影院 | 亚洲精品国产一区二区贰佰信息网 | 国产手机在线视频 | 精品久久久久中文字幕加勒比东京热 | xhameter中国| 国产精品人妻无码久久久奥特曼 | 亚洲伊人情人综合网站 | 国产AV在线传媒麻豆 | 全部免费特黄特色大片看片 | 韩国污动漫无遮掩无删减电脑版 | 少妇两个奶头喷出奶水了怎么办 | 中文字幕在线观看亚洲 | 久久AV国产麻豆HD真实乱 | 秀婷程仪公欲息肉婷在线观看 | 人人碰79免费视频 | 含羞草传媒在线观看 | 思思re热免费精品视频66 | 最近高清日本免费 | 世界上第一个得抑郁症的人是谁 | 老师小扫货水能么多叫出来 | 亚洲精品一二三区区别在哪 | 美女被爽cao免费漫画 | 羞羞影院午夜男女爽爽免费 | 免费视频亚洲 | japonensis护士| 国产在线观看91精品 | 亚洲欧美中文字幕高清在线 | 牛和人交videos欧美 | 99C视频色欲在线 | 中文字幕在线不卡日本v二区 |