Maison > interface Web > js tutoriel > Exemples d'extraits de code courants de JQuery pour le développement frontal Web (50)_jquery

Exemples d'extraits de code courants de JQuery pour le développement frontal Web (50)_jquery

WBOY
Libérer: 2016-05-16 15:41:51
original
1985 Les gens l'ont consulté

Cet article vous montre 50 extraits de code jquery qui peuvent vous aider dans vos projets javascript. Certains extraits de code sont des pratiques qui ne sont prises en charge que depuis jQuery 1.4.2, et d'autres sont des fonctions ou des méthodes très utiles qui peuvent vous aider à faire avancer les choses rapidement et correctement. Ce sont les extraits de code dont j'essaie de me souvenir pour obtenir les meilleures performances, donc si vous voyez quelque chose que vous pourriez faire mieux, n'hésitez pas à coller votre version dans les commentaires ! J'espère que vous avez trouvé cet article utile.

1. Comment créer des filtres imbriqués

//允许你减少集合中的匹配元素的过滤器, //只剩下那些与给定的选择器匹配的部分。在这种情况下, //查询删除了任何没(:not)有(:has) //包含class为“selected”(.selected)的子节点。.filter(":not(:has(.selected))")

Copier après la connexion

2. Comment réutiliser la recherche d'éléments

 var allItems = $("div.item"); var keepList = $("div#container1 div.item"); //现在你可以继续使用这些jQuery对象来工作了。例如, //基于复选框裁剪“keep list”,复选框的名称 //符合 
 <DIV>class names:
 $(formToLookAt + " input:checked").each(function () { keepList = keepList.filter("." + $(this).attr("name")); });
 </DIV>
Copier après la connexion

3. Toute personne qui utilise has() pour vérifier si un élément contient une certaine classe ou un certain élément

//jQuery 1.4.*包含了对这一has方法的支持。该方法找出 //某个元素是否包含了其他另一个元素类或是其他任何的 //你正在查找并要在其之上进行操作的东东。$("input").has(".email").addClass("email_icon");
Copier après la connexion

4. Comment utiliser jQuery pour changer de feuille de style

 //找出你希望切换的媒体类型(media-type),然后把href设置成新的样式表。
$(‘link[media=”screen”]').attr(‘href', ‘Alternative.css');
Copier après la connexion

5. Comment limiter la plage de sélection (en fonction des objectifs d'optimisation)

    //尽可能使用标签名来作为类名的前缀,     //这样jQuery就不需要花费更多的时间来搜索     //你想要的元素。还要记住的一点是,     //针对于你的页面上的元素的操作越具体化,     //就越能降低执行和搜索的时间。
 var in_stock = $('#shopping_cart_items input.is_in_stock');
 <ul id="shopping_cart_items"> <li><input type="radio" value="Item-X" name="item" class="is_in_stock" />Item X</li> <li><input type="radio" value="Item-Y" name="item" class="3-5_days" />Item Y</li> <li><input type="radio" value="Item-Z" name="item" class="unknown" />Item Z</li> </ul>
Copier après la connexion

6. Comment utiliser correctement ToggleClass

    //切换(toggle)类允许你根据某个类的     //是否存在来添加或是删除该类。     //这种情况下有些开发者使用:
 a.hasClass('blueButton') &#63; a.removeClass('blueButton') : a.addClass('blueButton');
//toggleClass允许你使用下面的语句来很容易地做到这一点

a.toggleClass(‘blueButton');
Copier après la connexion

7. Comment configurer les fonctions spécifiques à IE

  if ($.browser.msie) {
// Internet Explorer其实不那么好用

}
Copier après la connexion

8. Comment utiliser jQuery pour remplacer un élément

 $(‘#thatdiv').replaceWith(‘fnuh');
Copier après la connexion

9. Comment vérifier si un élément est vide

  if ($(‘#keks').html().trim()) {
//什么都没有找到;

}
Copier après la connexion

10. Comment trouver le numéro d'index d'un élément d'un ensemble non trié

 $("ul > li").click(function () { var index = $(this).prevAll().length; });
Copier après la connexion

11. Comment lier des fonctions à des événements

 $('#foo').bind('click', function () { alert('User clicked on "foo."'); });
Copier après la connexion

12. Comment ajouter ou ajouter du HTML aux éléments

 $(‘#lal').append(‘sometext');
Copier après la connexion

13. Comment utiliser des littéraux d'objet pour définir des attributs lors de la création d'éléments

 var e = $(“”, { href: “#”, class: “a-class another-class”, title: “…” });
Copier après la connexion

14. Comment utiliser plusieurs attributs pour filtrer

  //在使用许多相类似的有着不同类型的input元素时,     //这种基于精确度的方法很有用
   var elements = $('#someid input[type=sometype][value=somevalue]').get();
Copier après la connexion

15. Comment utiliser jQuery pour précharger des images

 jQuery.preloadImages = function () { for (var i = 0; i < arguments.length; i++) { $("<img />").attr('src', arguments[i]); } };
//用法 $.preloadImages(‘image1.gif', ‘/path/to/image2.png','some/image3.jpg');
Copier après la connexion

16. Comment définir un gestionnaire d'événements pour tout élément correspondant au sélecteur

 $('button.someClass').live('click', someFunction);//注意,在jQuery 1.4.2中,delegate和undelegate选项 //被引入代替live,因为它们提供了更好的上下文支持 //例如,就table来说,以前你会用 //.live() $("table").each(function () { $("td", this).live("hover", function () { $(this).toggleClass("hover"); }); });//现在用 $("table").delegate("td", "hover", function () { $(this).toggleClass("hover"); });
Copier après la connexion

17. Comment trouver un élément d'option qui a été sélectionné

 $(‘#someElement').find(‘option:selected');
Copier après la connexion

18. Comment masquer un élément qui contient un certain texte de valeur

 $(“p.value:contains(‘thetextvalue')”).hide();
Copier après la connexion

19. Si vous faites défiler automatiquement vers une certaine zone de la page

  jQuery.fn.autoscroll = function (selector) {

$(‘html,body').animate( { scrollTop: $(this ).offset().top },
500
);
}
//然后像这样来滚动到你希望去到的class/area上。

$(‘.area_name').autoscroll();
Copier après la connexion

20. Comment détecter différents navigateurs

 if( $.browser.safari) //检测Safari
if ($.browser.msie && $.browser.version > 6 ) //检测IE6及之后版本
if ($.browser.msie && $.browser.version <= 6 ) //检测IE6及之前版本
if ($.browser.mozilla && $.browser.version >= ‘1.8' ) //检测FireFox 2及之后版本
Copier après la connexion

21. Comment remplacer des mots dans une chaîne

 var el = $(‘#id'); el.html(el.html().replace(/word/ig, ”));
Copier après la connexion

22. Comment désactiver le menu contextuel du clic droit

$(document).bind(‘contextmenu', function (e) {

return false ;
});
Copier après la connexion

23. Comment définir un sélecteur personnalisé

$.expr[':'].mycustomselector = function(element, index, meta, stack){ // element- 一个DOM元素 // index – 栈中的当前循环索引 // meta – 有关选择器的元数据 // stack – 要循环的所有元素的栈 // 如果包含了当前元素就返回true // 如果不包含当前元素就返回false }; // 定制选择器的用法: $('.someClasses:test').doSomething();
Copier après la connexion

24. Comment vérifier si un élément existe

if ($(‘#someDiv' ).length) {
//你妹,终于找到了
}
Copier après la connexion

25. Comment utiliser jQuery pour détecter les clics droit et gauche de la souris

 $("#someelement").live('click', function (e) { if ((!$.browser.msie && e.button == 0) || ($.browser.msie && e.button == 1)) { alert("Left Mouse Button Clicked"); } else if (e.button == 2) { alert("Right Mouse Button Clicked"); } });
Copier après la connexion

26. Comment afficher ou supprimer la valeur par défaut dans le champ de saisie

//这段代码展示了在用户未输入值时,     //如何在文本类型的input域中保留     //一个默认值
 $(".swap").each(function (i) { wap_val[i] = $(this).val(); $(this).focusin(function () { if ($(this).val() == swap_val[i]) { $(this).val(""); } }).focusout(function () { if ($.trim($(this).val()) == "") { $(this).val(swap_val[i]); } }); });
Copier après la connexion

27. Comment masquer ou fermer automatiquement des éléments après un certain temps (prend en charge la version 1.4)

//这是1.3.2中我们使用setTimeout来实现的方式
 setTimeout(function () { $('.mydiv').hide('blind', {}, 500) }, 5000); //而这是在1.4中可以使用delay()这一功能来实现的方式(这很像是休眠) $(".mydiv").delay(5000).hide('blind', {}, 500);
Copier après la connexion

28. Comment ajouter dynamiquement des éléments créés au DOM

var newDiv = $(”);
newDiv.attr(‘id', ‘myNewDiv').appendTo(‘body');
Copier après la connexion

29. Comment limiter le nombre de caractères dans le champ "Zone de texte"

 jQuery.fn.maxLength = function (max) { this.each(function () { var type = this.tagName.toLowerCase(); var inputType = this.type &#63; this.type.toLowerCase() : null; if (type == "input" && inputType == "text" || inputType == "password") { this.maxLength = max; } else if (type == "textarea") { this.onkeypress = function (e) { var ob = e || event; var keyCode = ob.keyCode; var hasSelection = document.selection &#63; document.selection.createRange().text.length > 0 : this.selectionStart != this.selectionEnd; return !(this.value.length >= max && (keyCode > 50 || keyCode == 32 || keyCode == 0 || keyCode == 13) && !ob.ctrlKey && !ob.altKey && !hasSelection); }; this.onkeyup = function () { if (this.value.length > max) { this.value = this.value.substring(0, max); } }; } }); };
//用法 $(‘#mytextarea').maxLength(500);
Copier après la connexion

30. Comment créer un test de base pour une fonction

//把测试单独放在模块中 module("Module B"); test("some other test", function () { //指明测试内部预期有多少要运行的断言 expect(2); //一个比较断言,相当于JUnit的assertEquals equals(true, false, "failing test"); equals(true, true, "passing test"); });
Copier après la connexion

31. Comment cloner un élément dans jQuery

var cloned = $(‘#somediv').clone();
Copier après la connexion

32. Comment tester si un élément est visible dans jQuery

  if ($(element).is(‘:visible') ) {
//该元素是可见的
}
Copier après la connexion

33. Comment placer un élément au centre de l'écran

 jQuery.fn.center = function () { this.css('position', 'absolute'); this.css('top', ($(window).height() - this.height()) 
 / +$(window).scrollTop() + 'px'); this.css('left', ($(window).width() - this.width()) 
 / 2 + $(window).scrollLeft() + 'px'); return this; }
//这样来使用上面的函数: $(element).center(); 
Copier après la connexion

34. Comment mettre les valeurs de tous les éléments avec un nom spécifique dans un tableau

var arrInputValues = new Array();
$(“input[name='table[]']”).each(function () {
arrInputValues.push($(this ).val());
});
Copier après la connexion

35. Comment supprimer le HTML d'un élément

(function ($) { $.fn.stripHtml = function () { var regexp = /<("[^"]*"|'[^']*'|[^'">])*>/gi; this.each(function () { $(this).html($(this).html().replace(regexp, "")); }); return $(this); } })(jQuery);
//用法: $(‘p').stripHtml(); 
Copier après la connexion

36. Comment utiliser le plus proche pour obtenir l'élément parent

 $(‘#searchBox').closest(‘div');
Copier après la connexion

37. Comment enregistrer les événements jQuery à l'aide de Firebug et Firefox

// 允许链式日志记录 // 用法:$('#someDiv').hide().log('div hidden').addClass('someClass'); jQuery.log = jQuery.fn.log = function (msg) { if (console) { console.log("%s: %o", msg, this); } return this; };
Copier après la connexion

38. Comment forcer l'ouverture d'un lien dans une fenêtre pop-up

jQuery('a.popup').live('click', function () { newwindow = window.open($(this).attr('href'), '', 'height=200,width=150'); if (window.focus) { newwindow.focus(); } return false; });
Copier après la connexion

39. Comment forcer l'ouverture d'un lien dans un nouvel onglet

 jQuery('a.newTab').live('click', function () { newwindow = window.open($(this).href); jQuery(this).target = "_blank"; return false; });
Copier après la connexion

40. 在jQuery中如何使用.siblings()来选择同辈元素

  // 不这样做
 $('#nav li').click(function () { $('#nav li').removeClass('active'); $(this).addClass('active'); });
//替代做法是
 $('#nav li').click(function () { $(this).addClass('active').siblings().removeClass('active'); })
Copier après la connexion

41. 如何切换页面上的所有复选框

 var tog = false ;
// 或者为true,如果它们在加载时为被选中状态的话
 $('a').click(function () { $("input[type=checkbox]").attr("checked", !tog); tog = !tog; });
Copier après la connexion

42. 如何基于一些输入文本来过滤一个元素列表

//如果元素的值和输入的文本相匹配的话     //该元素将被返回
 $('.someClass').filter(function () { return $(this).attr('value') == $('input#someId').val(); })
Copier après la connexion

43. 如何获得鼠标垫光标位置x和y

$(document).ready(function () { $(document).mousemove(function (e) { $('#XY').html("X Axis : " + e.pageX + " | Y Axis " + e.pageY); }); });
Copier après la connexion

44. 如何把整个的列表元素(List Element,LI)变成可点击的

$("ul li").click(function () { window.location = $(this).find("a").attr("href"); return false; });
 <ul> <li><a href="#">Link 1</a></li> <li><a href="#">Link 2</a></li> <li><a href="#">Link 3</a></li> <li><a href="#">Link 4</a></li> </ul>
Copier après la connexion

45. 如何使用jQuery来解析XML(基本的例子)


function parseXml(xml) { //找到每个Tutorial并打印出author $(xml).find("Tutorial").each(function () { $("#output").append($(this).attr("author") + ""); }); }
Copier après la connexion

46. 如何检查图像是否已经被完全加载进来

$('#theImage').attr('src', 'image.jpg').load(function () { alert('This Image Has Been Loaded'); });
Copier après la connexion

47. 如何使用jQuery来为事件指定命名空间

//事件可以这样绑定命名空间 $('input').bind('blur.validation', function (e) { // ... }); //data方法也接受命名空间 $('input').data('validation.isValid', true);
Copier après la connexion

48. 如何检查cookie是否启用

var dt = new Date(); dt.setSeconds(dt.getSeconds() + 60); document.cookie = "cookietest=1; expires=" + dt.toGMTString(); var cookiesEnabled = document.cookie.indexOf("cookietest=") != -1; if (!cookiesEnabled) { //没有启用cookie }
Copier après la connexion

49. 如何让cookie过期

var date = new Date(); date.setTime(date.getTime() + (x * 60 * 1000)); $.cookie('example', 'foo', { expires: date });
Copier après la connexion

50. 如何使用一个可点击的链接来替换页面中任何的URL

 $.fn.replaceUrl = function () { var regexp = /((ftp|http|https):\/\/(\w+:{0,1}\w*@)&#63;(\S+)(:[0-9]+)&#63;(\/|\/([\w#!:.&#63;+=&%@!\-\/]))&#63;)/gi; this.each(function () { $(this).html( $(this).html().replace(regexp, '<a href="$1">$1</a>') ); }); return $(this); }
//用法  $(‘p').replaceUrl();
Copier après la connexion

以上内容就是给大家介绍了web前端开发JQuery常用实例代码片段(50个),希望大家喜欢。

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal