博客列表 >12月19号_ jQuery原理、基础选择器 - 九期线上班

12月19号_ jQuery原理、基础选择器 - 九期线上班

只猫
只猫原创
2019年12月28日 13:37:24713浏览

jQuery原理:封装js

写一个模拟jq选择器

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>jQuery的应用</title>
  6. <!-- 引入 -->
  7. <script src="jquery.js"></script>
  8. </head>
  9. <body>
  10. <input type="text" id="username" value="aaaa">
  11. <script type="text/javascript">
  12. //jQuery
  13. var jq = $('#username').val();
  14. console.log(jq);
  15. //jQuery是使用js封装的方法库
  16. //写一个id选择器
  17. function $$(selector){
  18. var obj = {
  19. val:function(){
  20. var flag = selector.substr(0,1);
  21. if(flag=='#'){
  22. var str = selector.substr(1,selector.length-1);
  23. var value = document.getElementById(str).value;
  24. return value;
  25. }
  26. if(flag=='.'){
  27. var str = selector.substr(1,selector.length-1);
  28. //类选择器只能拿到该类的第一个标签
  29. var value = document.getElementsByClassName(str)[0].value;
  30. return value;
  31. }
  32. }
  33. };
  34. return obj;
  35. }
  36. var myjq = $$('#username').val();
  37. console.log(myjq);
  38. //调用和jQuery一样
  39. </script>
  40. </body>
  41. </html>

jQuery基本选择器

基本:
1.id选择器 jQuery( “#id” )
2.元素选择器 jQuery( “element” )
3.类选择器 jQuery( “.class” )

层级:
后代 jQuery( “ancestor descendant” )
父子 jQuery( “parent > child” )
选择所有紧接在 “prev” 元素后的 “next” 元素 jQuery( “prev + next” )
匹配 “prev” 元素之后的所有 兄弟元素。具有相同的父元素,并匹配过滤“siblings”选择器。 jQuery( “prev ~ siblings” )

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>jquery基本选择器</title>
  6. <script src="jquery.js"></script>
  7. <style>
  8. .my{
  9. padding: 10px;
  10. margin: 20px;
  11. }
  12. </style>
  13. </head>
  14. <body>
  15. <div style="background: lightblue" id="blue" class="my">div1</div>
  16. <div style="background: lightgreen" id="green" class="my">div2</div>
  17. <div style="background: lightpink" id="pink" class="my">div3</div>
  18. <div style="background: lightyellow" id="yellow" class="my">
  19. <p>
  20. <i>javascript</i>
  21. <i>javascript</i>
  22. <i>javascript</i>
  23. </p>
  24. <p>
  25. <b>jquery</b>
  26. <b>jquery</b>
  27. <b>jquery</b>
  28. </p>
  29. <i>div的直接子元素1</i>
  30. <b>div的直接子元素2</b>
  31. </div>
  32. <script>
  33. //id选择器 返回的是一个jquery对象
  34. var selector1 = $('#blue');
  35. console.log(selector1); //拿到div1
  36. //类选择器 class
  37. var selector2 = $('.my');
  38. console.log(selector2); //获取到三个对象 div1 div2 div3
  39. //标签选择器 element
  40. var selector3 = $('div');
  41. console.log(selector3); //获取到三个对象 div1 div2 div3
  42. //后代选择器 ancestor
  43. var selector4 = $('#yellow p i');
  44. console.log(selector4); //选中3个i标签
  45. //父子选择器 child
  46. var selector5 = $('#yellow>i');
  47. console.log(selector5);
  48. //紧接在后面的元素 同级
  49. var selector6 = $('#yellow p + i');
  50. console.log(selector6);
  51. //在后面出现的同级元素
  52. var selector7 = $('#yellow > p ~ b');
  53. console.log(selector7); //选中div的直接子元素2
  54. </script>
  55. </body>
  56. </html>


总结:了解到jQuery是如何运作的,知道它是怎样去封装的,也就不难理解jQuery的用法。一些基本选择器和css的选择器基本一致,略有不同,可以触类旁通。

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议