国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

JavaScript實(shí)現(xiàn)兼容IE6的收起折疊與展開效果實(shí)例

2019-11-19 15:22:23
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文實(shí)例講述了JavaScript實(shí)現(xiàn)兼容IE6的收起折疊與展開效果。分享給大家供大家參考,具體如下:

收起折疊效果本身不難,但是div是否超出高度不應(yīng)該利用innerHTML去判斷,收起折疊的時(shí)候把所有div的innerHTML搞到一個(gè)變量又把一個(gè)變量的內(nèi)容通過截取字符串的方式,又將其放到div。下面提供一種通過div本身固有的高度來(lái)判斷div是否過高,如果過高則提供折疊收起的按鈕。

div的高度通過document.getElementById("div的id").offsetHeight去判斷,即使這個(gè)div的內(nèi)容是通過后端輸出的,document.getElementById("div的id").offsetHeight同樣可以取到div的最終高度,比如如下代碼:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>div折疊效果</title></head><body><div id="fold" style="border:1px #000 solid;height:100px;overflow:hidden">  <?php    echo "<p>s</p><p>s</p><p>s</p><p>s</p><p>s</p><p>s</p><p>s</p><p>s</p><p>s</p><p>s</p><p>s</p><p>s</p><p>s</p>";  ?></div></body></html><script>  alert(document.getElementById("fold").offsetHeight);</script>

運(yùn)行結(jié)果如下:

那么,我就是可以根據(jù)div的高度來(lái)做文章了。做出如下的效果:

HTML布局如下,用一個(gè)id為fold的div將你要收起、展開的內(nèi)容,夾起來(lái)。之后,在這個(gè)id為fold的div中放一個(gè)寬度為100%的按鈕,設(shè)置一個(gè)id為more_btn的按鈕,因?yàn)橐谀_本處在加載網(wǎng)頁(yè)就開始判斷,id為fold的div的高度,如果id為fold的div的高度過小,這個(gè)id為more_btn的按鈕就沒有顯示的必要了。同時(shí),將這個(gè)放內(nèi)容的div與button放在一個(gè)div里面。

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"><html>  <head>    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">    <title>div折疊效果</title>  </head>  <body>    <div style="border:1px #000 solid;">      <div id="fold">        <p>占位置</p><p>占位置</p><p>占位置</p><p>占位置</p><p>占位置</p><p>占位置</p>        <p>占位置</p><p>占位置</p><p>占位置</p><p>占位置</p><p>占位置</p><p>占位置</p>      </div>      <button id="more_btn" style="width:100%" onclick="showmore(this)">查看更多</button>    </div>  </body></html>

關(guān)鍵是接下來(lái)的網(wǎng)頁(yè)腳本,具體分兩部分,一部分是網(wǎng)頁(yè)加載部分,用于處理按鈕顯示否,div折疊否。還有一部分是按鈕點(diǎn)擊事件showmore。

<script type="text/javascript">  var div_height=document.getElementById("fold").offsetHeight;  var fold_flag=0;//用于標(biāo)志現(xiàn)在的div是展開還是折疊,初始為0,以為折疊中  if(div_height<100){//根據(jù)div的高度是否少于100px,判斷是否要隱藏按鈕    document.getElementById("more_btn").style.display="none";  }  else{//將div的高度強(qiáng)制定為100px,同時(shí)超出部分隱藏    document.getElementById("fold").style.overflow="hidden";    document.getElementById("fold").style.height="100px";  }  //id為more_btn的按鈕的點(diǎn)擊事件,按鈕被點(diǎn)擊的時(shí)候,將自己傳到這個(gè)事件中,形式參數(shù)為obj  function showmore(obj){    if (fold_flag == 0) {//展開的話,就是讓div的高度根據(jù)其內(nèi)容自適應(yīng),同時(shí)顯示所有內(nèi)容      document.getElementById("fold").style.overflow = "";      document.getElementById("fold").style.height = "";      obj.innerHTML="收起"http://按鈕的文字改變      fold_flag=1;//折疊標(biāo)志為1,意味現(xiàn)在為打開狀態(tài)    }    else{//收起就是回到原來(lái)的狀態(tài)。      document.getElementById("fold").style.overflow="hidden";      document.getElementById("fold").style.height="100px";      obj.innerHTML="查看更多"      fold_flag=0;    }  }</script>

不想用按鈕,你也可以設(shè)置一個(gè)居中的超級(jí)鏈接。

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript頁(yè)面元素操作技巧總結(jié)》、《JavaScript正則表達(dá)式技巧大全》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 江达县| 红河县| 临洮县| 洛阳市| 石嘴山市| 佛学| 牟定县| 甘孜县| 泽库县| 禹城市| 莫力| 锡林浩特市| 亳州市| 重庆市| 龙口市| 潢川县| 贞丰县| 临沭县| 且末县| 大竹县| 民勤县| 满城县| 项城市| 视频| 徐闻县| 白沙| 阳泉市| 电白县| 宜章县| 金寨县| 太仓市| 赣榆县| 西贡区| 静乐县| 宜黄县| 保德县| 漳州市| 女性| 高台县| 哈密市| 八宿县|