基于jquery的表头固定的若干方法_jquery
A:使用JQuery UI插件,用DIV替换table,overflow-y:hidden达到滚动,让 thead绝对定位达到固定的目的,方法如下:
(function($){
$.chromatable = {
defaults: {
width: "900px",
height: "300px",
scrolling: "yes"
}
};
$.fn.chromatable = function(options){
var options = $.extend({}, $.chromatable.defaults, options);
return this.each(function(){
var $this = $(this);
var $uniqueID = $(this).attr("ID") + ("wrapper");
$(this).css('width', options.width).addClass("_scrolling");
$(this).wrap('
$(".scrolling_outer").css({'position':'relative'});
$("#"+$uniqueID).css(
{'border':'1px solid #CCCCCC',
'overflow-x':'hidden',
'overflow-y':'auto',
'padding-right':'17px'
});
$("#"+$uniqueID).css('height', options.height);
$("#"+$uniqueID).css('width', options.width);
$(this).before($(this).clone().attr("id", "").addClass("_thead").css(
{'width' : 'auto',
'display' : 'block',
'position':'absolute',
'border':'none',
'border-bottom':'1px solid #CCC',
'top':'1px'
}));
$('._thead').children('tbody').remove();
$(this).each(function( $this ){
if (options.width == "100%" || options.width == "auto") {
$("#"+$uniqueID).css({'padding-right':'0px'});
}
if (options.scrolling == "no") {
$("#"+$uniqueID).before('Expand table');
$("#"+$uniqueID).css({'padding-right':'0px'});
$(".expander").each(
function(int){
$(this).attr("ID", int);
$( this ).bind ("click",function(){
$("#"+$uniqueID).css({'height':'auto'});
$("#"+$uniqueID+" ._thead").remove();
$(this).remove();
});
});
$("#"+$uniqueID).resizable({ handles: 's' }).css("overflow-y", "hidden");
}
});
$curr = $this.prev();
$("thead:eq(0)>tr th",this).each( function (i) {
$("thead:eq(0)>tr th:eq("+i+")", $curr).width( $(this).width());
});
if (options.width == "100%" || "auto"){
$(window).resize(function(){
resizer($this);
});
}
});
};
function resizer($this) {
$curr = $this.prev();
$("thead:eq(0)>tr th", $this).each( function (i) {
$("thead:eq(0)>tr th:eq("+i+")", $curr).width( $(this).width());
});
};
})(jQuery);
页面调用如下:
...
<script> <BR>$(function(){ <BR>$("#yourTableID").chromatable({ <BR>width: "900px", <BR>height: "400px", <BR>scrolling: "yes" <BR>}); <BR>}); <BR></script>
...
Check out this header | Look here's another one | Wow, look at me! |
---|---|---|
Some content goes in here | Praesent vitae ligula nec orci pretium vestibulum | Maecenas tempus dictum libero |
Quisque in wisi quis orci tincidunt fermentum | Mauris aliquet mattis metus | Etiam eu ante non leo egestas nonummy |
此方法IE和FF的兼容性都很好,推荐。
B:利用css滤镜实现,但FF不支持微软的东西,不兼容。DOM如下:
列头 | 列头 | 列头 | ||||
---|---|---|---|---|---|---|
h1 | h2 | h3 | h4 | h5 | h6 | h7 |
a | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
b | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
c | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
C:最简单的方法当然是写2个table,用DIV的overflow-y:auto来实现,兼容性绝对没问题,麻烦之处在于2个table的对齐问题,另外用脚本赋予高度的话,需要加onresize()方法。DOM如下:
列头 | 列头 | 列头 | ||||
---|---|---|---|---|---|---|
h1 | h2 | h3 | h4 | h5 | h6 | h7 |
a | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
b | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
c | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
a | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
b | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
c | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
d | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
e | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
f | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
g | 单元格2 | 单元格3 | 单元格4 | 单元格5 | 单元格6 | 单元格7 |
有时候最笨的方法也可能是最简单最好的方法,这样写的兼容性绝对安全,灵活性也不错。

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Explication détaillée de la méthode de remplacement de la chaîne JavaScript et de la FAQ Cet article explorera deux façons de remplacer les caractères de chaîne dans JavaScript: le code JavaScript interne et le HTML interne pour les pages Web. Remplacer la chaîne dans le code JavaScript Le moyen le plus direct consiste à utiliser la méthode Remplace (): str = str.replace ("trouver", "remplacer"); Cette méthode remplace uniquement la première correspondance. Pour remplacer toutes les correspondances, utilisez une expression régulière et ajoutez le drapeau global G: str = str.replace (/ fi

Ce tutoriel vous montre comment intégrer une API de recherche Google personnalisée dans votre blog ou site Web, offrant une expérience de recherche plus raffinée que les fonctions de recherche de thème WordPress standard. C'est étonnamment facile! Vous pourrez restreindre les recherches à Y

Cette série d'articles a été réécrite à la mi-2017 avec des informations à jour et de nouveaux exemples. Dans cet exemple JSON, nous examinerons comment nous pouvons stocker des valeurs simples dans un fichier à l'aide du format JSON. En utilisant la notation de paire de valeurs clés, nous pouvons stocker n'importe quel type

Améliorez votre présentation de code: 10 surligneurs de syntaxe pour les développeurs Partager des extraits de code sur votre site Web ou votre blog est une pratique courante pour les développeurs. Le choix du bon surligneur de syntaxe peut améliorer considérablement la lisibilité et l'attrait visuel. T

Vous voici donc, prêt à tout savoir sur cette chose appelée Ajax. Mais qu'est-ce que c'est exactement? Le terme Ajax fait référence à un regroupement lâche de technologies utilisées pour créer un contenu Web interactif dynamique. Le terme Ajax, inventé à l'origine par Jesse J

Tirez parti de jQuery pour les dispositions de page Web sans effort: 8 plugins essentiels JQuery simplifie considérablement la mise en page de la page Web. Cet article met en évidence huit puissants plugins jQuery qui rationalisent le processus, particulièrement utile pour la création de sites Web manuels

Cet article présente une sélection organisée de plus de 10 didacticiels sur les cadres JavaScript et JQuery Model-View-Controller (MVC), parfait pour augmenter vos compétences en développement Web au cours de la nouvelle année. Ces tutoriels couvrent une gamme de sujets, de Foundatio

Points de base Ceci dans JavaScript fait généralement référence à un objet qui "possède" la méthode, mais cela dépend de la façon dont la fonction est appelée. Lorsqu'il n'y a pas d'objet actuel, cela fait référence à l'objet global. Dans un navigateur Web, il est représenté par Window. Lorsque vous appelez une fonction, cela maintient l'objet global; mais lors de l'appel d'un constructeur d'objets ou de l'une de ses méthodes, cela fait référence à une instance de l'objet. Vous pouvez modifier le contexte de ceci en utilisant des méthodes telles que Call (), Appliquer () et Bind (). Ces méthodes appellent la fonction en utilisant la valeur et les paramètres donnés. JavaScript est un excellent langage de programmation. Il y a quelques années, cette phrase était
