Cheerio DOM操作深度指南:轻松玩转HTML元素操作

一、基础DOM操作

1. 元素选择器

Cheerio支持多种选择器语法:

  • 基本选择器
javascript 复制代码
// 选择所有div元素
$('div')

// 选择ID为content的元素
$('#content')

// 选择class为highlight的元素
$('.highlight')
  • 属性选择器
javascript 复制代码
// 选择所有带有href属性的a标签
$('a[href]')

// 选择href为特定值的a标签
$('a[href="https://example.com"]')
  • 组合选择器
javascript 复制代码
// 选择div下的所有p元素
$('div p')

// 选择div或span元素
$('div, span')

// 选择第一个p元素
$('p:first')

2. 属性操作

javascript 复制代码
// 获取属性
const href = $('a').attr('href');

// 设置属性
$('a').attr('href', 'https://new-url.com');

// 删除属性
$('a').removeAttr('href');

二、元素遍历

1. 基础遍历方法

javascript 复制代码
// 遍历所有元素
$('div').each((index, element) => {
    console.log($(element).text());
});

// 获取第一个元素
const first = $('div').first();

// 获取最后一个元素
const last = $('div').last();

2. 选择器遍历

javascript 复制代码
// 获取父元素
const parent = $('div').parent();

// 获取子元素
const children = $('div').children();

// 获取兄弟元素
const siblings = $('div').siblings();

三、元素创建和修改

1. 创建元素

javascript 复制代码
// 创建单个元素
const newDiv = $('<div>');
const newDivWithClass = $('<div class="highlight">');

// 创建复杂结构
const complexElement = $('<div class="container"><h1>Title</h1><p>Content</p></div>');

2. 修改元素

javascript 复制代码
// 添加内容
$('div').append('<p>New content</p>');
$('div').prepend('<p>First content</p>');

// 替换内容
$('div').html('<p>Updated content</p>');

// 添加文本
$('div').text('New text content');

四、高级DOM操作

1. 链式操作

javascript 复制代码
// 链式调用
$('div')
    .addClass('highlight')
    .append('<p>New content</p>')
    .attr('data-id', '123');

五、实战案例:复杂DOM操作

1. 表格数据提取

javascript 复制代码
const tableData = [];
$('table tr').each((index, row) => {
    const rowData = [];
    $(row).find('td').each((tdIndex, cell) => {
        rowData.push($(cell).text());
    });
    tableData.push(rowData);
});

2. 动态内容生成

javascript 复制代码
const data = [
    { title: 'Item 1', description: 'Description 1' },
    { title: 'Item 2', description: 'Description 2' }
];

const $list = $('<ul>');
data.forEach(item => {
    const $item = $('<li>')
        .append(`<h3>${item.title}</h3>`)
        .append(`<p>${item.description}</p>`);
    $list.append($item);
});

结语

Cheerio的DOM操作能力强大而灵活,更加多的用法请参考官网

如果你喜欢本教程,记得点赞+收藏!关注我获取更多JavaScript开发干货。

相关推荐
小蒜学长2 分钟前
springboot房地产销售管理系统的设计与实现(代码+数据库+LW)
java·数据库·spring boot·后端
FreeBuf_11 分钟前
新型域名前置攻击利用Google Meet、YouTube、Chrome及GCP构建流量隧道
前端·chrome
c0detrend16 分钟前
技术架构设计:如何打造一个高性能的Chrome截图插件
前端·chrome
幽络源小助理22 分钟前
8、幽络源微服务项目实战:前端登录跨域同源策略处理+axios封装+权限的递归查询增删改+鉴权测试
前端·微服务·架构
邂逅星河浪漫23 分钟前
【LangChain4j+Redis】会话记忆功能实现
java·spring boot·后端·阿里云·langchain4j·会话记忆
API开发26 分钟前
apiSQL+GoView:一个API接口开发数据大屏
前端·后端·api·数据可视化·数据大屏·apisql
运维开发王义杰28 分钟前
nodejs:揭秘 npm 脚本参数 -- 的妙用与规范
前端·npm·node.js
我是日安35 分钟前
从零到一打造 Vue3 响应式系统 Day 18 - Reactive:深入 Proxy 的设计思路
前端·vue.js
你的人类朋友36 分钟前
🍃说说Base64
前端·后端·安全