jQuery實(shí)現(xiàn)鎖定頁面元素(表格列)
摘要
在拖動(dòng)滾動(dòng)條時(shí),對(duì)頁面元素進(jìn)行橫向、縱向鎖定。
介紹
對(duì)于展現(xiàn)內(nèi)容較多的頁面,在滾動(dòng)時(shí),我們經(jīng)常需要對(duì)一些重要的元素進(jìn)行鎖定。這些元素經(jīng)常是表格的行、列,也可能是搜索條件,或者是其他重要信息。
對(duì)于表格列的鎖定,目前主要有三種方法。
1.表格控件
2.js生成fixtable之類填充
3.js+css
第一種,算是最簡(jiǎn)單的方法。但是用控件的缺點(diǎn)實(shí)在太多了,其中一個(gè)與本文有直接相關(guān)的缺點(diǎn)是,部分控件對(duì)多級(jí)表頭的鎖定支持的很差。
第二種,思路很清晰,但是實(shí)現(xiàn)起來非常復(fù)雜,維護(hù)成本過高。
第三種,正是本文所用的方法。目前網(wǎng)上也有多篇相關(guān)文章,但是就使用場(chǎng)景來說太局限了,沒有對(duì)這一類問題進(jìn)行更高程度的抽象。
我想要的是:不只是表格,只要是想要鎖定的元素,只需要添加一個(gè)標(biāo)識(shí),再最多額外寫一行代碼就可以完成批量鎖定。并且內(nèi)部實(shí)現(xiàn)代碼要盡量簡(jiǎn)單。
用法
對(duì)需要縱向鎖定的元素添加樣式lock-col,橫向鎖定的添加lock-row。在nayiLock方法中傳入滾動(dòng)的div所對(duì)應(yīng)的id。
完整例子
<!DOCTYPE>
<html>
<head>
? ? <title>鎖定</title>
? ? <meta http-equiv="X-UA-Compatible" charset="utf-8"/>
? ? <script src="../../js/jquery-1.7.2.min.js" type="text/javascript"></script>
<style type="text/css">
table td, th{
? ? text-align: center;
? ? border:#dee9ef 1px solid;
}
</style>
<script>?
jQuery(function(){
? ? nayiLock("aDiv");
? ? //支持多級(jí)表頭的鎖定
? ? nayiLock("bDiv");
? ? //支持對(duì)多個(gè)div的鎖定
})?
//scrollDivId ? 滾動(dòng)的div的id
function nayiLock(scrollDivId){
? ? jQuery("#" + scrollDivId).scroll(function(){
? ? ? ? var left = jQuery("#" + scrollDivId).scrollLeft();
? ? ? ? jQuery(this).find(".lock-col").each(function(){
? ? ? ? ? ? jQuery(this).css({"position":"relative","left":left,"background-color":"white","z-index":jQuery(this).hasClass("lock-row")?20:10});
? ? ? ? });
? ? ? ? var top = jQuery("#" + scrollDivId).scrollTop();
? ? ? ? jQuery(this).find(".lock-row").each(function(){
? ? ? ? ? ? jQuery(this).css({"position":"relative","top":top,"background-color":"white","z-index":jQuery(this).hasClass("lock-col")?20:9});
? ? ? ? });
? ? });
}
</script>
</head>
<body id="myBody">
<div id="aDiv" style="width:600px;height:200px;overflow:auto;">
? ? <div class="lock-row lock-col" >
? ? ? ? <span id="span1" >span1</span>
? ? </div>
? ? <table id="table1" style="width:800px;height:250px;" >
? ? ? ? <thead>
? ? ? ? ? ? <tr>
? ? ? ? ? ? ? ? <th id="testTh" class="lock-col lock-row">序號(hào)</th>
? ? ? ? ? ? ? ? <th class=" lock-row">表頭1</th>
? ? ? ? ? ? ? ? <th class="lock-row">表頭2</th>
? ? ? ? ? ? </tr>
? ? ? ? </thead>
? ? ? ? <tbody>
? ? ? ? ? ? <tr>
? ? ? ? ? ? ? ? <td class="lock-col">1</td>
? ? ? ? ? ? ? ? <td class="">test</td>
? ? ? ? ? ? ? ? <td>test</td>
? ? ? ? ? ? </tr>
? ? ? ? ? ? <tr>
? ? ? ? ? ? ? ? <td class="lock-col">2</td>
? ? ? ? ? ? ? ? <td class="">test</td>
? ? ? ? ? ? ? ? <td>test</td>
? ? ? ? ? ? </tr>
? ? ? ? </tbody> ? ?
? ? </table>
</div>
<div id="bDiv" style="width:600px;height:100px;overflow:auto;">
? ? <table id="table1" style="width:800px;height:150px;">
? ? ? ? <thead>
? ? ? ? ? ? <tr>
? ? ? ? ? ? ? ? <th colspan="2" class="lock-col lock-row">
? ? ? ? ? ? ? ? ? ? colspan="2"
? ? ? ? ? ? ? ? </th>
? ? ? ? ? ? ? ? <th class="lock-row">
? ? ? ? ? ? ? ? ? ? colspan="1"
? ? ? ? ? ? ? ? </th>
? ? ? ? ? ? </tr>
? ? ? ? ? ? <tr>
? ? ? ? ? ? ? ? <th id="testTh" class="lock-col lock-row">序號(hào)</th>
? ? ? ? ? ? ? ? <th class="lock-col lock-row">表頭1</th>
? ? ? ? ? ? ? ? <th class="lock-row">表頭2</th>
? ? ? ? ? ? </tr>
? ? ? ? </thead>
? ? ? ? <tbody>
? ? ? ? ? ? <tr>
? ? ? ? ? ? ? ? <td class="lock-col">1</td>
? ? ? ? ? ? ? ? <td class="lock-col">test</td>
? ? ? ? ? ? ? ? <td>test</td>
? ? ? ? ? ? </tr>
? ? ? ? ? ? <tr>
? ? ? ? ? ? ? ? <td class="lock-col">2</td>
? ? ? ? ? ? ? ? <td class="lock-col">test</td>
? ? ? ? ? ? ? ? <td>test</td>
? ? ? ? ? ? </tr>
? ? ? ? </tbody> ? ?
? ? </table>
</div>
</body>
</html>注:對(duì)低版本ie的兼容還是沒找到j(luò)s上的直接解決方法。建議使用expression方法。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- jQuery 判斷頁面元素是否存在的代碼
- JQuery顯示隱藏頁面元素的方法總結(jié)
- jQuery獲得頁面元素的絕對(duì)/相對(duì)位置即絕對(duì)X,Y坐標(biāo)
- JQuery 簡(jiǎn)便實(shí)現(xiàn)頁面元素?cái)?shù)據(jù)驗(yàn)證功能
- jQuery獲取頁面元素絕對(duì)與相對(duì)位置的方法
- jquery獲得頁面元素的坐標(biāo)值實(shí)現(xiàn)思路及代碼
- jQuery頁面元素動(dòng)態(tài)添加后綁定事件丟失方法,非 live
- jQuery實(shí)現(xiàn)動(dòng)態(tài)控制頁面元素的方法分析
- jQuery使用之處理頁面元素用法實(shí)例
- jquery 查找iframe父級(jí)頁面元素的實(shí)現(xiàn)代碼
相關(guān)文章
Iframe實(shí)現(xiàn)跨瀏覽器自適應(yīng)高度解決方法
這篇文章主要介紹了Iframe實(shí)現(xiàn)跨瀏覽器自適應(yīng)高度解決方法,通過父層容器的應(yīng)用來實(shí)現(xiàn)這一功能,非常實(shí)用的一個(gè)技巧,需要的朋友可以參考下2014-09-09
ajax jquery實(shí)現(xiàn)頁面某一個(gè)div的刷新效果
這篇文章主要給大家介紹了關(guān)于ajax jquery實(shí)現(xiàn)頁面某一個(gè)div的刷新效果的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
jQuery簡(jiǎn)單實(shí)現(xiàn)彩色云標(biāo)簽效果示例
這篇文章主要介紹了jQuery簡(jiǎn)單實(shí)現(xiàn)彩色云標(biāo)簽效果,結(jié)合實(shí)例形式分析了jQuery隨機(jī)數(shù)運(yùn)算與頁面元素樣式動(dòng)態(tài)操作相關(guān)技巧,需要的朋友可以參考下2016-08-08
jquery實(shí)現(xiàn)tr元素的上下移動(dòng)示例代碼
讓tr元素的上下移動(dòng)的方法有很多,本文為大家介紹下使用jquery是實(shí)現(xiàn)的,感興趣的朋友可以參考下2013-12-12
jQuery懸停文字提示框插件jquery.tooltipster.js用法示例【附demo源碼下載】
這篇文章主要介紹了jQuery懸停文字提示框插件jquery.tooltipster.js用法,涉及jQuery文字提示框插件的引入與調(diào)用實(shí)現(xiàn)技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2016-07-07
jquery mobile的觸控點(diǎn)擊事件會(huì)多次觸發(fā)問題的解決方法
這篇文章主要介紹了jquery mobile的觸控點(diǎn)擊事件會(huì)多次觸發(fā)問題的解決方法以及替代方法,需要的朋友可以參考下2014-05-05
jQuery EasyUI API 中文文檔 - Draggable 可拖拽
jQuery EasyUI API 中文文檔 - Draggable 可拖拽,使用jQuery EasyUI的朋友可以參考下。2011-09-09
jQuery模擬完美實(shí)現(xiàn)經(jīng)典FLASH導(dǎo)航動(dòng)畫效果【附demo源碼下載】
這篇文章主要介紹了jQuery模擬完美實(shí)現(xiàn)經(jīng)典FLASH導(dǎo)航動(dòng)畫效果,通過jQuery響應(yīng)鼠標(biāo)事件動(dòng)態(tài)操作頁面元素樣式實(shí)現(xiàn)flash切換的效果,非常經(jīng)典實(shí)用,文末還提供了demo源碼供讀者下載學(xué)習(xí)或使用,需要的朋友可以參考下2016-11-11

