WEB基础之: jQuery 核心

所有案例示例

<body>
    <ul>
        <li id="i1">l1</li>
        <li id="i2">l2</li>
        <li id="i3">l3</li>
    </ul>
    <script src="jquery-3.5.1.js"></script>
</body>

1. jQuery 核心函数

  • jQuery([selector,[context]]): 接收一个包含 CSS 选择器的字符串,然后用这个字符串去匹配一组元素。

    • // 找到所有 ul 元素,并且这些元素都必须是 body 元素的子元素。
      $("body > ul");
      
  • jQuery(callback): $(document).ready()的简写。允许你绑定一个在DOM文档载入完成后执行的函数。

    • $(function(){
        // 当DOM加载完成后,执行的函数。
      });
      
      jQuery(function($) {
        // 使用 $(document).ready() 的简写,同时内部的 jQuery 代码依然使用 $ 作为别名,而不管全局的 $ 为何。
      });
      
  • jQuery(html,[ownerDocument]): 根据提供的原始 HTML 标记字符串,动态创建由 jQuery 对象包装的 DOM 元素。同时设置一系列的属性、事件等。

    • 创建元素的过程中,这个函数的内部,是通过临时创建一个元素,并将这个元素的 innerHTML 属性设置为给定的标记字符串,来实现标记到 DOM 元素转换的。所以,这个函数既有灵活性,也有局限性。

      // 动态创建一个 div 元素,并将它追加到 body 元素中。
      $("<div><p>Hello</p></div>").appendTo("body");
      
      // 创建一个 <input> 元素,同时设定 type 属性、属性值,以及一些事件。
      $("<input>", {
        type: "text",
        val: "Test",
        focusin: function() {
          $(this).addClass("active");
        },
        focusout: function() {
          $(this).removeClass("active");
        }
      }).appendTo("form");
      

2. jQuery 对象访问

  • each(callback):以每一个匹配的元素作为上下文来执行一个函数。意味着,每次执行传递进来的函数时,函数中的this关键字都指向一个不同的DOM元素(每次都是一个不同的匹配元素)。而且,在每次执行函数时,都会给函数传递一个表示作为执行环境的元素在匹配的元素集合中所处位置的数字值作为参数(从零开始的整型)。

    • // 列表循环1,结果只包含列表内容
      for (let i=0; i<$('li').length;i++) {
        console.log($('li').eq(i).text());
      }// 列表循环2,结果包含列表内容与列表其他对象。
      for (let i in $('li')) {
        console.log($('li').eq(i).text());
      }// 列表循环3,结果只包含列表内容
      $('li').each(function (k, v) {
        console.log(k,v.innerText;
      });
      
    • 函数返回 ‘false’ 将停止循环 (就像在普通的循环中使用 ‘break’)。返回 ‘true’ 跳至下一个循环(就像在普通的循环中使用’continue’)。

      • // 终止each循环
        $('li').each(function (k, v) {
            if (k===1) {
            return false;
          }
          console.log(k,v.innerText);
        });
        
  • length: jQuery 对象中元素的个数。

    • $("ul").length;
      
  • get: 取得其中一个匹配的元素。 num表示取得第几个匹配的元素。从0开始,返回的是DOM对象,类似的有eq(index)不过eq(index)返回的是jQuery对象。

    • $('li').get(0).innerText;	// "l1"
      
  • index([selector|element]): 搜索匹配的元素,并返回相应元素的索引值,从0开始计数。

    • 如果参数为空,那么返回值就是这个jQuery对象集合中第一个元素相对于其同辈元素的位置。

    • 如果参数是一组DOM元素或者jQuery对象,那么返回值就是传递的元素相对于原先集合的位置。

    • 如果参数是一个选择器,那么返回值就是原先元素相对于选择器匹配元素中的位置。如果找不到匹配的元素,则返回-1。

    • $('li').index(document.getElementById('i3')); //1,传递一个DOM对象,返回这个对象在原先集合中的索引位置
      $('li').index($('#i2')); //1,传递一个jQuery对象
      $('li').index($('li:gt(0)')); //1,传递一组jQuery对象,返回这个对象中第一个元素在原先集合中的索引位置
      $('#i2').index('li'); //1,传递一个选择器,返回#i2在所有li中的索引位置
      $('#i2').index(); //1,不传递参数,返回这个元素在同辈中的索引位置。  
      

3. 数据缓存

  • data([key],[value]): 在元素上存放或读取数据,返回jQuery对象。

    • 当参数只有一个key的时候,为读取该jQuery对象对应DOM中存储的key对应的值。

    • 当参数为两个时,为像该jQuery对象对应的DOM中存储key-value键值对的数据。

    • 如果jQuery集合指向多个元素,那将在所有元素上设置对应数据。 这个函数不用建立一个新的expando,就能在一个元素上存放任何格式的数据,而不仅仅是字符串。

    • $('ul').data('k',100);	// 写入数据
      $('ul').data('k');		// 读取数据,100;如果没有返回undefined。
      
  • removeData([name|list]): 在元素上移除存放的数据。

    • $('ul').removeData('k');
      

4. 插件

  • jQuery.extend([deep], target, object1, [objectN]): 为jQuery增加新方法。 如果第一个参数设置为true,则jQuery返回一个深层次的副本,递归地复制找到的任何对象。否则的话,副本会与原对象共享结构。 未定义的属性将不会被复制,然而从对象的原型继承的属性将会被复制。

    • <script>
          jQuery.extend({
          min: function (a,b) { return a < b ? a : b;},
          max: function (a,b) { return a>b ? a : b;}
      })
      </script>
      jQuery.min(1,2)  // 1
      jQuery.min(3,2)  // 2
      
  • jQuery.fn.extend(object): 给任意的jQuery标签对象添加一个方法(通常用来制作插件)。

    • // 制作快速检查是否选中插件
      jQuery.fn.extend({
        check: function() {
          return this.each(function() { this.checked = true; });
        },
        uncheck: function() {
          return this.each(function() { this.checked = false; });
        }
      });
      
      // $("input[type=checkbox]").check();
      // $("input[type=radio]").uncheck();
      

jQuery 杂项

1. 数组和对象操作

  • jQuery.each(object, *[callback]*): 回调函数拥有两个参数:第一个为对象的成员或数组的索引,第二个为对应变量或内容。如果需要退出 each 循环可使回调函数返回 false,其它返回值将被忽略。

    • let a1 = ['l11', 'l22', 'l33'];
      $.each(a1, function(k,v) {
        console.log(k,v);
      });
      
已标记关键词 清除标记
相关推荐
<p> <strong> </strong> </p> <p class="MsoNormal" style="text-align:left;margin-left:21pt;text-indent:21pt;"> <br /> </p> <p class="MsoNormal"> <strong><span style="font-size:18px;"></span></strong> </p> <p class="ql-long-24357476"> <strong><span style="font-size:18px;color:#E53333;"><strong>想学好</strong></span><strong><span style="font-size:18px;color:#E53333;">JAVA必须要报两万的培训班吗?</span></strong><span style="color:#E53333;"></span><span id="__kindeditor_bookmark_start_82__"></span><br /> </strong> </p> <p class="ql-long-24357476"> <span id="__kindeditor_bookmark_end_83__"></span><strong><span style="color:#337FE5;">【课程背景】</span></strong> </p> <p class="ql-long-24357476"> <strong>JAVA是市场份额最大的编程语言,每天各大招聘网站上都会有数万个JAVA开发工程师的在招岗位,但是JAVA的技术体系庞大复杂,要想扎实掌握JAVA不是一件容易的事,线上学习相比线下两万起的高昂费用便宜了很多,而且具备学习时间灵活的优势,但是线上学习的劣势也很明显,没有线下那种学习氛围,碰到问题没法解决,在家学习很容易偷懒,极简JAVA学习营充分考虑到这些问题,通过每日实战编程练习,分队pk,助教答疑,作业点评,作业讲解,项目答辩等诸多环节充分激发你的学习热情,解决你学习中碰到的问题,让你花十分之一的钱学到JAVA的精髓,开启你的人生逆袭之路。</strong> </p> <p class="ql-long-24357476"> <strong><br /> </strong> </p> <strong><span style="color:#337FE5;">【专项的贴心服务】</span> <p class="ql-long-24357476"> 1. 学练结合:定期布置视频任务和编程实战练习:通过每天的视频任务统一大家的进度,以便同学更好的交流,针对每天的任务会有相应的编程实战练习,通过练习内化知识。<br /> 2. 分队PK:将就业营的同学分成几队,通过作业统计表统计每队提交作业情况进行PK,激发你的学习动力。<br /> 3. 助教讲师答疑:碰到任何问题,发到群里,助教和讲师十分钟内帮你解决问题,扫清学习中的障碍。<br /> 4. 助教点评讲解作业:你每天提交作业都会有助教进行点评,让你知道有什么问题怎么解决,每三天一次视频讲解作业,互动解答问题<br /> 5. 项目答辩:每个阶段学完会有项目答辩,通过做项目巩固前一阶段的知识点,锻炼编码能力。 </p> <p class="ql-long-24357476"> <img src="https://img-bss.csdnimg.cn/202007070905305336.png" alt="" /> </p> <p class="ql-long-24357476"> <span style="color:#337FE5;">【往期训练营学习展示】</span> </p> <p class="ql-long-24357476"> <img src="https://img-bss.csdnimg.cn/202007070914574571.png" alt="" /> </p> <p class="ql-long-24357476"> <span style="color:#337FE5;">【套餐内容简介】</span> </p> <p class="ql-long-24357476"> 本套课以市场就业和职位需求为核心,从JAVA入门到多领域实战,设计出学习路线,共分为二十大模块,分别是:JAVA面向对象、Object类与常用API、集合框架、IO流、反射注解、多线程与网络编程、Object类与常用API等等。 </p> <p> 同时采用理论讲解加实战演练的方式,既能让学员听懂听明白达到理解透彻,又能够在一个个真实实战案例中,让学员掌握真正有用的开发技能,从而进阶 JAVA 工程师! </p> <p> <br /> </p> <p class="ql-long-24357476"> 套餐中一共包含21门JAVA程,助你从零进阶JAVA工程师! </p> <p class="ql-long-24357476"> <span style="color:#337FE5;">阶段一:</span><span style="color:#337FE5;">JAVA</span><span style="color:#337FE5;">基</span><span style="color:#337FE5;">础</span> </p> <p class="ql-long-24357476"> 课程1:《极简JAVA学习营开营篇》 </p> <p class="ql-long-24357476"> 课程2:《极简JAVA:JAVA面向对象》 </p> <p class="ql-long-24357476"> 课程3:《极简JAVA:Object类与常用API》 </p> <p class="ql-long-24357476"> 课程4:《极简JAVA:集合框架》 </p> <p class="ql-long-24357476"> 课程5:《极简JAVA:IO流》 </p> <p class="ql-long-24357476"> 课程6:《极简JAVA:反射注解》 </p> <p class="ql-long-24357476"> 课程7:《极简JAVA:多线程与网络编程》 </p> <p class="ql-long-24357476"> <span style="color:#337FE5;">阶段二:</span><span style="color:#337FE5;">数据库入门</span> </p> <p class="ql-long-24357476"> 课程8:《极简JAVA:MySql数据库》 </p> <p class="ql-long-24357476"> 课程9:《极简JAVA:JDBC与连接池》 </p> <p class="ql-long-24357476"> <span style="color:#337FE5;">阶段三:</span><span style="color:#337FE5;">JAVA WEB</span> </p> <p class="ql-long-24357476"> 课程10:《极简JAVA:HTML5与CSS3》 </p> <p class="ql-long-24357476"> 课程11:《极简JAVA:极简JAVA十一:Javascript与Jquery》 </p> <p> 课程12:《极简JAVA:BootStrap》 </p> <p class="ql-long-24357476"> 课程13:《极简JAVA:JAVA Web》 </p> <p class="ql-long-24357476"> <span style="color:#337FE5;">阶段四:框架实战</span> </p> <p class="ql-long-24357476"> 课程14:《极简JAVA:Mavean入门》 </p> <p class="ql-long-24357476"> 课程15:《极简JAVA:MyBatis框架》 </p> <p class="ql-long-24357476"> 课程16:《极简JAVA:Spring框架》 </p> <p class="ql-long-24357476"> 课程17:《极简JAVA:Spring Mvc》 </p> <p class="ql-long-24357476"> <span id="__kindeditor_bookmark_end_251__"></span><span id="__kindeditor_bookmark_end_247__"></span>课程18:《极简JAVA:Oracle数据库》 </p> <p class="ql-long-24357476"> 课程19:《极简JAVA:Git入门》 </p> <p class="ql-long-24357476"> 课程20:《极简JAVA:Linux入门》 </p> <p class="ql-long-24357476"> 课程21:《极简JAVA:SpringBoot》 </p> <p> <br /> </p> <p class="ql-long-24357476"> <span style="color:#337FE5;">【课程特色】</span> </p> <p class="ql-long-24357476"> 1、易理解:讲师思路清晰、节奏明确、从易到难讲解透彻明白; </p> <p class="ql-long-24357476"> 2、知识全:知识全面系统,从JAVA入门到实战,由易到难,让你彻底掌握JAVA开发; </p> <p class="ql-long-24357476"> 3、重实战:涵盖大量实战项目,锻炼你的动手实操能力,面向工作编程; </p> <p> <br /> </p> <p class="ql-long-24357476"> <span style="color:#337FE5;">【面向人群】</span> </p> <p class="ql-long-24357476"> 1、在校计算机专业或者对软件编程感兴趣的学生; </p> <p class="ql-long-24357476"> 2、零基础想学JAVA却不知道从何入手 </p> <p class="ql-long-24357476"> 3、囊中羞涩,面对两万起的JAVA培训班不忍直视 </p> <p class="MsoNormal"> 4、在职没有每天大块的时间专门学习JAVA </p> </strong>
©️2020 CSDN 皮肤主题: 1024 设计师:白松林 返回首页