Vous trouverez ci-dessous quelques conseils d'utilisation de Jquery. Par exemple, il existe des fonctions telles que la désactivation du clic droit, le masquage du texte de la zone de texte de recherche, l'ouverture de liens dans de nouvelles fenêtres, la détection des navigateurs, le préchargement des images, le changement de style de page, la hauteur égale de toutes les colonnes, le contrôle dynamique de la taille de la police de la page et l'obtention du Valeur X et valeur Y du pointeur de la souris, vérifiez si l'élément est vide, remplacez l'élément, chargez paresseusement, vérifiez si l'élément existe dans la collection Jquery, rendez le DIV cliquable, clonez l'objet, centrez l'élément, comptez le nombre d'éléments, utilisez la bibliothèque de classes Jquery sur l'hôte Google, désactivez Jquery. L'effet est de résoudre le problème de conflit entre la bibliothèque de classes Jquery et d'autres bibliothèques de classes Javascript.
1. Le clic droit est interdit
$(document).ready(function(){ $(document).bind("contextmenu",function(e){ return false; }); });
2. Masquer le texte de la zone de texte de recherche
Masquer lorsque vous cliquez dans le champ de recherche, la valeur. (un exemple peut être trouvé ci-dessous dans les champs de commentaire)
$(document).ready(function() { $("input.text1").val("Enter your search text here"); textFill($('input.text1')); }); function textFill(input){ //input focus text function var originalvalue = input.val(); input.focus( function(){ if( $.trim(input.val()) == originalvalue ){ input.val(''); } }); input.blur( function(){ if( $.trim(input.val()) == '' ){ input.val(originalvalue); } }); }
3. Ouvrir le lien dans une nouvelle fenêtre
XHTML 1.0 Strict n'autorise pas cet attribut dans le code, utilisez-le donc pour garder le code valide.
$(document).ready(function() { //Example 1: Every link will open in a new window $('a[href^="http://"]').attr("target", "_blank"); //Example 2: Links with the rel="external" attribute will only open in a new window $('a[@rel$='external']').click(function(){ this.target = "_blank"; }); }); // how to use <A href="http://www.opensourcehunter.com" rel=external>open link</A>
4. Détecter le navigateur
Remarque : Dans la version jQuery 1.4, $.support a remplacé la variable $.browser
$(document).ready(function() { // Target Firefox 2 and above if ($.browser.mozilla && $.browser.version >= "1.8" ){ // do something } // Target Safari if( $.browser.safari ){ // do something } // Target Chrome if( $.browser.chrome){ // do something } // Target Camino if( $.browser.camino){ // do something } // Target Opera if( $.browser.opera){ // do something } // Target IE6 and below if ($.browser.msie && $.browser.version <= 6 ){ // do something } // Target anything above IE6 if ($.browser.msie && $.browser.version > 6){ // do something } });
5. Précharger les images
Ce morceau de code empêchera le chargement de toutes les images, ce qui peut être utile si vous avez un site avec beaucoup d'images.
$(document).ready(function() { jQuery.preloadImages = function() { for(var i = 0; i<ARGUMENTS.LENGTH; jQuery(?<img { i++)>").attr("src", arguments[i]); } } // how to use $.preloadImages("image1.jpg"); });
6. Changement de style de page
$(document).ready(function() { $("a.Styleswitcher").click(function() { //swicth the LINK REL attribute with the value in A REL attribute $('link[rel=stylesheet]').attr('href' , $(this).attr('rel')); }); // how to use // place this in your header <LINK rel=stylesheet type=text/css href="default.css"> // the links <A class="Styleswitcher" href="#" rel=default.css>Default Theme</A> <A class="Styleswitcher" href="#" rel=red.css>Red Theme</A> <A class="Styleswitcher" href="#" rel=blue.css>Blue Theme</A> });
7. Colonnes de même hauteur
Si deux colonnes CSS sont utilisées, cette méthode peut être utilisée pour rendre les hauteurs des deux colonnes identiques.
$(document).ready(function() { function equalHeight(group) { tallest = 0; group.each(function() { thisHeight = $(this).height(); if(thisHeight > tallest) { tallest = thisHeight; } }); group.height(tallest); } // how to use $(document).ready(function() { equalHeight($(".left")); equalHeight($(".right")); }); });
8. Contrôler dynamiquement la taille de la police de la page
Les utilisateurs peuvent modifier la taille de la police de la page
$(document).ready(function() { // Reset the font size(back to default) var originalFontSize = $('html').css('font-size'); $(".resetFont").click(function(){ $('html').css('font-size', originalFontSize); }); // Increase the font size(bigger font0 $(".increaseFont").click(function(){ var currentFontSize = $('html').css('font-size'); var currentFontSizeNum = parseFloat(currentFontSize, 10); var newFontSize = currentFontSizeNum*1.2; $('html').css('font-size', newFontSize); return false; }); // Decrease the font size(smaller font) $(".decreaseFont").click(function(){ var currentFontSize = $('html').css('font-size'); var currentFontSizeNum = parseFloat(currentFontSize, 10); var newFontSize = currentFontSizeNum*0.8; $('html').css('font-size', newFontSize); return false; }); });
9. Revenir en haut de la page
Pour un retour en douceur (animé) vers le sommet (ou n'importe quel endroit).
$(document).ready(function() { $('a[href*=#]').click(function() { if (location.pathname.replace(/^\//,'') == this.pathname.replace(/^\//,'') && location.hostname == this.hostname) { var $target = $(this.hash); $target = $target.length && $target || $('[name=' + this.hash.slice(1) +']'); if ($target.length) { var targetOffset = $target.offset().top; $('html,body') .animate({scrollTop: targetOffset}, 900); return false; } } }); // how to use // place this where you want to scroll to <A name=top></A> // the link <A href="#top">go to top</A> });
11. Obtenez la valeur XY du pointeur de la souris
Vous voulez savoir où se trouve le curseur de votre souris ?
$(document).ready(function() { $().mousemove(function(e){ //display the x and y axis values inside the div with the id XY $('#XY').html("X Axis : " + e.pageX + " | Y Axis " + e.pageY); }); // how to use <DIV id=XY></DIV> });
12. Vérifiez si l'élément est vide
Cela vous permettra de vérifier si un élément est vide.
$(document).ready(function() { if ($('#id').html()) { // do something } });
13. Remplacer les éléments
Vous voulez remplacer un div, ou autre chose ?
$(document).ready(function() { $('#id').replaceWith(' <DIV>I have been replaced</DIV> '); });
14. Fonction de chargement retardé de jQuery
Vous voulez retarder quelque chose ?
$(document).ready(function() { window.setTimeout(function() { // do something }, 1000); });
15. Supprimer la fonction de mot
Vous souhaitez supprimer un ou plusieurs mots ?
$(document).ready(function() { var el = $('#id'); el.html(el.html().replace(/word/ig, "")); });
16. Vérifiez si l'élément existe dans la collection d'objets jquery
Testez simplement avec la propriété .length si l'élément existe.
$(document).ready(function() { if ($('#id').length) { // do something } });
17. Rendre l'intégralité du DIV cliquable
Vous voulez rendre le div complet cliquable ?
$(document).ready(function() { $("div").click(function(){ //get the url from href attribute and launch the url window.location=$(this).find("a").attr("href"); return false; }); // how to use <DIV><A href="index.html">home</A></DIV> });
18. Conversion entre ID et classe.
Lorsque vous modifiez la taille de la fenêtre, basculez entre ID et Classe
$(document).ready(function() { function checkWindowSize() { if ( $(window).width() > 1200 ) { $('body').addClass('large'); } else { $('body').removeClass('large'); } } $(window).resize(checkWindowSize); });
19. Cloner un objet
Cloner un div ou un autre élément.
$(document).ready(function() { var cloned = $('#id').clone(); // how to use <DIV id=id></DIV> });
20. Positionnez l'élément au milieu de l'écran
Centrez un élément au centre de votre écran.
$(document).ready(function() { jQuery.fn.center = function () { this.css("position","absolute"); this.css("top", ( $(window).height() - this.height() ) / 2+$(window).scrollTop() + "px"); this.css("left", ( $(window).width() - this.width() ) / 2+$(window).scrollLeft() + "px"); return this; } $("#id").center(); });
21. Écrivez votre propre sélecteur
Écrivez vos propres sélecteurs.
$(document).ready(function() { $.extend($.expr[':'], { moreThen1000px: function(a) { return $(a).width() > 1000; } }); $('.box:moreThen1000px').click(function() { // creating a simple js alert box alert('The element that you have clicked is over 1000 pixels wide'); }); });
22. Comptez le nombre d'éléments
Comptez un élément.
$(document).ready(function() { $("p").size(); });
23. Utilisez vos propres balles
Vous souhaitez utiliser vos propres puces au lieu d'utiliser les puces standard ou les images ?
$(document).ready(function() { $("ul").addClass("Replaced"); $("ul > li").prepend("‒ "); // how to use ul.Replaced { list-style : none; } });
24. Référencez la bibliothèque de classes Jquery sur l'hôte Google
Laissez Google héberger le script jQuery pour vous. Cela peut être fait de deux manières.
[code]//Exemple 1
http://www.google.com/jsapi">>
http://ajax.googleapis.com/ajax/libs/jquery/1.2.6/jquery.min.js"> SCRIPT>
// Exemple 2 :(le moyen le meilleur et le plus rapide)
[/code">http://ajax.googleapis.com/ajax/libs/jquery/1.2.6/jquery.min.js">[/code ]
25. Désactiver l'effet Jquery (animation)
Désactivez tous les effets jQuery
$(document).ready(function() { jQuery.fx.off = true; });
26. Solution aux conflits avec d'autres bibliothèques Javascript
Pour éviter les conflits avec d'autres bibliothèques de votre site Web, vous pouvez utiliser cette méthode jQuery et attribuer un nom de variable différent au lieu du signe dollar.
$(document).ready(function() { var $jq = jQuery.noConflict(); $jq('#id').show(); });