当前位置: 首页 > news >正文

jQuery零基础入门速通(中)

大家好,我是小黄。

在上一篇文章中,我们初步了解了jQuery的基本概念、环境搭建、选择器、基本的DOM操作以及事件处理。接下来,我们将继续深入探讨jQuery的DOM操作和事件处理,以及一些实用的技巧和高级用法。

五、高级DOM操作

5.1 插入与删除节点

jQuery提供了简便的方法来插入和删除DOM节点。

  • 插入节点
    • append():在每个匹配元素内部的最后插入内容。
    • prepend():在每个匹配元素内部的开头插入内容。
    • after():在每个匹配元素之后插入内容。
    • before():在每个匹配元素之前插入内容。

示例


  • 删除节点
    • remove():移除匹配元素及其子元素。
    • empty():移除匹配元素的所有子元素。

示例

// 移除所有<p>元素及其内容
$("p").remove();// 清空所有<p>元素的内容,但保留<p>元素本身
$("p").empty();
5.2 复制节点
  • clone():复制匹配的元素集合。可以传递一个布尔值参数来指示是否同时复制事件处理器和数据。

示例

// 复制<div>元素,但不复制事件处理器
var clonedDiv = $("div").clone(false);// 将复制的<div>元素添加到文档中
$("body").append(clonedDiv);
5.3 遍历DOM树

jQuery提供了parent()children()siblings()等方法来遍历DOM树。

  • parent():获取匹配元素的父元素。
  • children([selector]):获取匹配元素的所有子元素(可以通过可选的选择器进行过滤)。
  • siblings([selector]):获取匹配元素的所有兄弟元素(可以通过可选的选择器进行过滤)。

示例

// 获取<li>元素的父元素<ul>
var ulElement = $("li").parent();// 获取<ul>元素的所有直接子<li>元素
var liElements = $("ul").children("li");// 获取<li>元素的所有兄弟<li>元素
var siblingLiElements = $("li").siblings("li");
六、高级事件处理

6.1 事件委托

事件委托是一种将事件监听器添加到父元素上,而不是直接添加到目标元素上的技术。这样做的好处是可以减少内存消耗,并且即使目标元素是动态添加的,事件也能正常触发。

示例

// 使用事件委托来处理动态添加的<button>元素的点击事件
$("#container").on("click", "button", function() {alert("Button clicked!");
});
在这个例子中,即使<button>元素是在#container之后添加的,点击事件仍然会被触发。

6.2 命名空间与自定义事件

jQuery允许为事件添加命名空间,这有助于在移除特定事件时避免影响到其他事件。此外,jQuery还支持触发自定义事件。

  • 命名空间:在事件类型后面加上一个点(.)和命名空间名称。
  • 自定义事件:使用trigger()方法触发自定义事件名称。

示例

// 绑定带有命名空间的事件
$("#myElement").on("click.myNamespace", function() {alert("Custom namespaced event triggered!");
});// 触发自定义事件
$("#myElement").trigger("click.myNamespace");// 移除带有命名空间的事件
$("#myElement").off("click.myNamespace");// 触发自定义事件
$("#myElement").trigger("myCustomEvent");// 绑定自定义事件的处理函数
$("#myElement").on("myCustomEvent", function() {alert("My custom event triggered!");
});
6.3 事件对象

jQuery事件处理函数接收一个事件对象作为参数,该对象包含了事件的详细信息,如事件类型、触发事件的元素、鼠标位置等。

示例

$("#myButton").click(function(event) {// 阻止默认行为(例如,阻止链接跳转)event.preventDefault();// 阻止事件冒泡event.stopPropagation();// 获取触发事件的元素var targetElement = event.target;// 获取事件类型var eventType = event.type;// ...其他事件属性
});

通过本文的学习,你进一步掌握了jQuery的高级DOM操作和事件处理技术。这些技能将帮助你在实际项目中更高效地处理DOM元素和用户交互。

各位小伙伴还在BOSS直聘hr已读不回?!试试这个宝藏小程序!大家快看这里。

创作不易,各位帅气漂亮的小伙伴点个关注再走呗!!

http://www.lryc.cn/news/494668.html

相关文章:

  • 【设计模式系列】中介者模式(十八)
  • PDF版地形图矢量出现的问题
  • 小迪安全第四十二天笔记 简单的mysql注入 mysql的基础知识 用户管理数据库模式 mysql 写入与读取 跨库查询
  • 11.25.2024刷华为OD
  • 你真的会用饼图吗?JVS-智能BI饼图组件深度解析
  • HarmonyOS Next 模拟器安装与探索
  • 医学机器学习:数据预处理、超参数调优与模型比较的实用分析
  • 单片机知识总结(完整)
  • 【C++】auto和decltype类型推导关键字
  • OGRE 3D----3. OGRE绘制自定义模型
  • ARM + Linux 开发指南
  • facebook欧洲户开户条件有哪些又有何优势?
  • 算法训练(leetcode)二刷第三十一天 | 1049. 最后一块石头的重量 II、494. 目标和、*474. 一和零
  • 软件测试丨Pytest生命周期与数据驱动
  • Figma入门-原型交互
  • 网络安全防范技术
  • Java - JSR223规范解读_在JVM上实现多语言支持
  • win10系统部署RAGFLOW+Ollama教程
  • 基于Python制作一个简易UI界面
  • 鲁菜大师程伟华到访金宫川派味业
  • Linux设置jar包开机自启动
  • IoTDB 常见问题 QA 第一期
  • 【linux学习指南】linux捕捉信号
  • git如何快速拉取已经提交的mr进行验证
  • 【阿来来gis规划师工具箱说明书】h07四分标注
  • 【大数据学习 | 面经】HDFS的三副本机制和编码机制
  • lua-cjson 例子
  • java面向对象知识点: 封装,构造,重载
  • go的math/rand随机数生成器
  • JiaJia-CP-1,2,3的WP(2)