[GPT] 网页中某些dom内容是通过 js 数据异步渲染的,nodejs 怎么获取网页解析这些数据
要处理使用JavaScript异步渲染内容的网页,您可以在 JavaScript 蜘蛛中使用 Puppeter 或 Playwright 等无头浏览器来获取网页,然后与动态渲染的内容进行交互。
下面是一个使用Puppeteer的例子:
const puppeteer = require('puppeteer');
(async () => { // Launch a headless browser const browser = await puppeteer.launch(); const page = await browser.newPage();
// Navigate to the webpage await page.goto('http://example.com');
// Wait for the asynchronous content to load await page.waitForSelector('#async_content');
// Extract the data from the dynamically rendered content const data = await page.evaluate(() => { const asyncContent = document.querySelector('#async_content'); return asyncContent.innerHTML; });
// Process or parse the extracted data as needed console.log(data);
// Close the browser await browser.close(); })();
在本例中,Puppeter 用于启动无头浏览器并导航到所需的网页。我们使用 page.waitForSelector() 来等待包含异步呈现内容的特定元素出现在页面上。
然后,我们使用 page.eevaluate() 在页面的上下文中执行自定义 JavaScript 代码,并提取包含动态呈现内容的元素的内部 HTML。
您可以修改 page.eevaluate() 函数以提取特定数据或对内容执行任何必要的解析或操作。
在运行代码之前,请记住使用 npm install puppeteer 或 yarn add puppeteer 安装 Puppeteer。
Cool:ChatAI
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
2016-07-02 [php-src] 扩展中封装业务与 call_user_function 的使用建议