中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > JavaScript Table行定位效果
RDFa介紹——構(gòu)建更友好的web頁面 回到列表 CSS定位屬性Position詳解
 JavaScript Table行定位效果

作者:cloudgamer 時間: 2009-09-17 文檔類型:原創(chuàng) 來自:藍色理想

第 1 頁 JavaScript Table行定位效果 [1]
第 2 頁 JavaScript Table行定位效果 [2]
第 3 頁 JavaScript Table行定位效果 [3]
第 4 頁 JavaScript Table行定位效果 [4]
第 5 頁 JavaScript Table行定位效果 [5]
第 6 頁 JavaScript Table行定位效果 [6]
第 7 頁 JavaScript Table行定位效果 [7]
第 8 頁 JavaScript Table行定位效果 [8]

【覆蓋select】

只要用到了定位,就不得不面對一個老對手“ie6的select”。
我在之前的文章也介紹過一些解決方法(參考這里的覆蓋select),這里不能直接隱藏select,那看來只能用iframe了。
但用iframe有一個很大的問題,在ie6測試下面的代碼,并拖動滾動條:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "<html xmlns="<body>
<style type="text/css">
body{height:1000px;}
.t{height:300px;width:200px; border:1px solid; position:absolute; background:#FFF;top:0;left:0;}
</style>
<iframe class="t" id="t"></iframe>
<select></select><br />
<select></select><br />
<select></select><br />
<select></select><br />
<select></select><br />
<select></select><br />
<select></select><br />
<select></select><br />
<select></select><br />
<select></select><br />
</body>
</html>

可以看到,即使是iframe,在拖動滾動條的時候,select仍然在后面閃啊閃,在本程序中這個現(xiàn)象會尤其明顯。
看來還得用隱藏select的方法,最好的做法是只隱藏在新table后面的select,而不影響其他select的正常顯示。
那關(guān)鍵就是如何判斷select是否在新table后面,這個可以通過位置坐標判斷,剛好可以用到上面的getBoundingClientRect。
一般的思路是判斷新table和select的坐標,根據(jù)位置判斷select的顯示和隱藏。
但如果有多個實例,可能會導(dǎo)致select在一個實例中要隱藏,卻在另一個要顯示的情況。

為了解決沖突,程序給select加了一個_count屬性作為計數(shù)器,用來記錄有多少實例把該select隱藏了。
如果當(dāng)前實例判斷該select要隱藏,就給其_count加1,隱藏后存放到實例的_selects集合中。
在恢復(fù)顯示_selects中的select時,先給select的_count減1,如果得到的_count是0,那說明沒有其他實例要隱藏它,就可以設(shè)置顯示了,最后清空_selects集合。
在判斷是否隱藏select前還必須恢復(fù)一次該實例_selects里面的select,否則就會造成_count只加不減的情況。

程序中的SetSelect方法就是用來判斷和設(shè)置select的:

this.ResetSelect();
var rect = this._nTable.getBoundingClientRect();
//把需要隱藏的放到_selects集合
this._selects = Filter(this._oTable.getElementsByTagName("select"), Bind(this, function(o){
    var r = o.getBoundingClientRect();
    if(r.top <= rect.bottom && r.bottom >= rect.top){
        o._count ? o._count++ : (o._count = 1);//防止多個實例沖突
        //設(shè)置隱藏
        var visi = o.style.visibility;
        if(visi != "hidden"){ o._css = visi; o.style.visibility = "hidden"; }
       
        return true;
    }
}))

其中ResetSelect方法是用來恢復(fù)顯示select的:

forEach(this._selects, function(o){ !--o._count && (o.style.visibility = o._css); });
this._selects = [];

但這個方法在快速滾屏?xí)r還是無能為力,而且select越多效率也隨之下降,各位有更好方法的話歡迎交流。

【Chrome一個bug】

在測試的時候發(fā)現(xiàn)Chrome一個bug,測試下面代碼:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "<html xmlns="<body>
<table border="1">
    <tr>
        <td id="tt"></td>
    </tr>
</table>
<div id="t"></div>
<script>
document.getElementById("t").offsetWidth;
document.getElementById("tt").innerHTML = "<select><option>test</option></select>";
</script>
</body>
</html>

一個毫不相干的操作居然令table沒有自動撐開,加上前面的問題,看來Chrome的路還很長啊。

使用說明

實例化一個TableFixed對象只需要一個參數(shù)table的id:

new TableFixed("idTable");

實例化時有4個可選屬性:
Index: 0,//tr索引
Auto: true,//是否自動定位
Pos: 0,//自定義定位位置百分比(0到1)
Hide: false//是否隱藏(不顯示)

其中Index和Pos在實例化之后就不能使用。
要修改克隆行可以用Clone方法,其參數(shù)是要克隆tr的索引。
要修改自定義定位位置可以用SetPos方法,其參數(shù)是要定位的位置百分比。

具體使用請參考實例。

程序源碼

代碼拷貝框

[Ctrl+A 全部選擇 然后拷貝]

下載完成測試代碼

原文:http://www.cnblogs.com/cloudgamer/archive/2009/05/18/TableFixed.html

本文鏈接:http://m.95time.cn/tech/web/2009/7012.asp 

出處:藍色理想
責(zé)任編輯:bluehearts

上一頁 JavaScript Table行定位效果 [7] 下一頁

◎進入論壇網(wǎng)頁制作、WEB標準化版塊參加討論,我還想發(fā)表評論。

相關(guān)文章 更多相關(guān)鏈接
再談動態(tài)添加樣式規(guī)則
Javascript函數(shù)類型判斷解決方案
認識Javascript數(shù)組
解讀javascript的計時器 I
JavaScript獲取事件對象的注意點
作者文章 更多作者文章
JavaScript 浮動定位提示效果
JavaScript 顏色梯度和漸變效果
JavaScript Tween算法及緩動效果
仿Apple滑動條(拖動)產(chǎn)品展示效果
JavaScript 圖片切割效果
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大福“敬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:8/81個記錄/頁 轉(zhuǎn)到 頁 共8個記錄

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔(dān)一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責(zé)任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2