91网首页-91网页版-91网在线观看-91网站免费观看-91网站永久视频-91网站在线播放

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

網頁中單一表格橫縱表頭鎖定的細節

admin
2010年10月24日 8:50 本文熱度 4089
    之前搗鼓了一個可以鎖定橫縱表頭的HTML表格,不過那天急著回家就只給了一個demo示例。這不長假過后又挺忙活,一拖就給拖到周末了。這個東西雖然不是什么新奇的玩意,不過里面的細節還是有不少,所以有知其然并希望知其所以然的博友,歡迎來一起討論討論。

    實現這個鎖定表頭的效果其實到有很多的方法,不過使用單一表格來實現,需要借助IE的css支持的expression表達式關鍵字。另外就是對瀏覽器布局原理的理解,如果不熟悉可以參考我原來寫的兩篇文章。所以要實現這個效果,我們需要也只需要做兩件事情,一是使用css提供的expression功能;二是使用css提供的position修改布局方式的能力。

    首先我們來看上部表頭的鎖定,我們知道對于container元素,如果要限定內部內容的大小,并出現滾動條。因該是用如下css來定義可以作為容器的元素,這里我使用的是div來做為表格的容器,代碼如下:
<div onselectstart="return false" style="border-color:Blue;border-width:2px;border-style:solid;height:100%;width:700px;overflow:auto;cursor:default;">
<!-- table -->
</div>
// 重要的就是那個overflow:auto。順便說一下,弄出滾動條這個css設置雖然非常的easy,不過不知道IE這么搞的,這個容器只能在height上設置百分比,而width的大小必須是固定的值,否這width方向上就不能出現滾動條

    其實如果就這樣我們把table放入div中,就已經是一個可以滾動的表格了,只是所有的單元格也都在滾動而已。所以我們需要修改表格中不希望滾動的單元格的布局方式,tr和td的默認布局方式都是static。如果要讓tr相對于div不動,那么在div中的滾動條滾動到scrollTop為100時,相對不動的tr應該停留在相對于div左上角的(0, 100)的位置上。這個相對性我們可以用<tr style="position:relative">獲得,那么top為100怎么弄呢?顯然這就是expression的事情了,我們需要把行上的css設置為<tr style="top:expression(表格容器.scrollTop)">。這個表格容器是什么呢?就是div,使用dom的層次來查找因該是:
this.parentElement.parentElement.parentElement.scrollTop;
不過可以使用offsetParent來優化,減少引用深度,簡化為:
this.offsetParent.scrollTop;

    那么被鎖定的行的完整css就因該是:
<tr style="position: relative; top: expression(this.offsetParent.scrollTop);"></tr>

    這么簡單啊?就這么簡單,不過問題當然還是有啦。這樣的鎖定效果有兩個主要的問題:一是表格背景由于默認是透明的,所以如果真的滾動起來,字是不動了,不過都是鏤空的重疊效果。解決辦法很簡單,就是給tr設置上背景顏色就可以啦。第二個問題,比較郁悶,搞了很久才在別人的幫助下搞定。當tr的position為relative后,這個tr里面的td的border屬性就貌似失效了,就是不管設置什么顏色,死活都顯示不出來:
    TdBorderEmpty.png
    后來在putee同學的幫助下,發現原來需要把tr中的每個td的position屬性也都設置成relative,border才能顯示出來!

    搞定了上面的表頭,我們再來搞左邊的表頭。左邊原理和上面一樣,只是被expression控制的元素是td而不是tr啦。expression中引用div的代碼就以該是:
this.parentElement.parentElement.parentElement.parentElement.scrollTop;
比鎖定tr多了一個層次的引用,這是使用offsetParent來優化和tr還不同,tr的offsetParent就是容器div;而td的offsetParent還是td,暈!所以要用this.parentElement來取offsetParent,不過這時取到的又是table,再次暈。所以這個優化只能減少一個parent層次的引用,優化為:
this.parentElement.offsetParent.parentElement.scrollTop;

    那么被鎖定的列的完整css就因該是:
<td style="position: relative; left: expression(this.parentElement.offsetParent.parentElement.scrollTop);"></tr>

    搞定了橫縱兩個方向表頭的鎖定,結果去發現表頭的單元格的邊框不太對勁,怎么都是雙倍的邊線呢?我已經設置了table-collapse為collapse,而且單元格的border設置為solid 1px blue。結果發現這又是position設成了relative后帶來的問題,解決辦法是只給每個表頭單元格設置border的兩個邊,比如top和left或者right和bottom。下圖是表頭單元格兩種不同border樣式設置的效果:     
    
    最后就是Grid左上角那個相對于容器div靜止的部分,當然這個部分的tr和td除了需要同時包含上面說到的鎖定行表頭和列表頭的css expression外,還有一個問題就是這個部分的單元格的zIndex必須是表格兩個表頭中最大的,才能保證不管真么滾動表頭,始終能顯示這個部分。另外又是由于IE的問題,我們不能把左上角這個部分通過colspan和rowspan合并成一個td,如果合并那么除了第一行外的其行,將在表頭滾動時被覆蓋掉。所以這個部分的每一行仍然是一個單獨的td,只是在水平方向上作了合并優化。

該文章在 2010/10/24 8:50:04 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 国产成a人亚 | 成人精品玖玖资源 | 国产免费观看 | 午夜免费一级视频 | 国产一区二区成人 | 中文字幕开心激情 | 日本到成人免费网站 | 日本精品a在 | 日韩欧美一二三区 | 日韩精品sp | 国产喷水抽搐视频 | 日本韩国欧美午夜 | 日韩欧美中文在线 | 国产激动情五月天 | 加勒比一本大道香 | 欧美在线观看综合 | 精品e本大 | 日韩一进一 | 欧美午夜视频一区 | 国精产品一品二品国 | 国产制服丝袜你 | 国产精品视频一区二 | 欧美日韩激情播放 | 福利一区二区在线 | 日本二码 | 69午夜国产精品 | 国产97碰| 欧美在线直播 | 国产欧美制服丝袜 | 日韩福利 | 国产片第一福利片 | 日本+国产+欧美 | 国产日韩视频一区 | 伦子系列午睡沙发 | 人人看人人爱97 | 日韩免费影院 | 日本亚洲国产黄m | 亚洲无码动漫在线观看视频 | 精品综合色 | 国产粗语刺激 | 韩国美女一区二区 |