有没有什么办法将网页的指定dom元素及子元素的所有css导出?
网友回复
写一个油猴脚本实现,具体的脚本代码
// ==UserScript== // @name 网页DOM树和CSS样式导出器 // @namespace http://tampermonkey.net/ // @version 1.0 // @description 导出网页完整的DOM树结构和所有CSS样式 // @author You // @match *://*/* // @grant none // @icon  // ==/UserScript== (function() { 'use strict'; // 创建导出按钮 function createExportButton() { // 检查按钮是否已存在 if (document.getElementById('export-dom-css-btn')) return; // 创建按钮 const button = document.createElement('button'); button.id = 'export-dom-css-btn'; button.textContent = '导出DOM和CSS'; button.style.cssText = ` position: fixed; top: 20px; right: 20px; z-index: 999999; padding: 10px 15px; background: #4CAF50; color: white; border: none; border-radius: 5px; cursor: pointer; font-size: 14px; box-shadow: 0 2px 10px rgba(0,0,0,0.3); `; // 添加悬停效果 button.addEventListener('mouseenter', () => { button.style.background = '#45a049'; }); button.addEventListener('mouseleave', () => { button.style.background = '#4CAF50'; }); // 点击事件 button.addEventListener('click', exportDOMAndCSS); // 添加到页面 document.body.appendChild(button); } // 导出DOM和CSS function exportDOMAndCSS() { try { // 获取完整的DOM树 const domTree = getDOMTree(); // 获取所有CSS样式 const cssStyles = getAllCSSStyles(); // 生成完整的HTML文档 const fullHTML = generateFullHTML(domTree, cssStyles); // 下载文件 downloadFile(fullHTML, `dom-export-${new Date().toISOString().slice(0, 19).replace(/:/g, '-')}.html`); alert('DOM树和CSS样式导出成功!'); } catch (error) { console.error('导出失败:', error); alert('导出失败: ' + error.message); } } // 获取完整的DOM树结构 function getDOMTree() { // 克隆整个文档 const clonedDoc = document.cloneNode(true); // 移除脚本标签以避免执行 const scripts = clonedDoc.querySelectorAll('script'); scripts.forEach(script => script.remove()); // 移除导出按钮 const exportBtn = clonedDoc.getElementById('export-dom-css-btn'); if (exportBtn) exportBtn.remove(); // 移除可能的油猴脚本元素 const tampermonkeyElements = clonedDoc.querySelectorAll('[id^="tampermonkey"], [class^="tampermonkey"]'); tampermonkeyElements.forEach(el => el.remove()); return clonedDoc; } // 获取所有CSS样式 function getAllCSSStyles() { let allCSS = ''; // 1. 获取所有内联样式表 for (let i = 0; i < document.styleSheets.length; i++) { try { const sheet = document.styleSheets[i]; const cssText = getCSSFromStyleSheet(sheet); if (cssText) { allCSS += `/* 样式表 ${i + 1} */\n${cssText}\n\n`; } } catch (error) { console.warn(`无法获取样式表 ${i}:`, error); } } // 2. 获取所有内联样式 const inlineStyles = getInlineStyles(); if (inlineStyles) { allCSS += `/* 内联样式 */\n${inlineStyles}\n\n`; } // 3. 获取计算样式(可选,会很大) // const computedStyles = getComputedStyles(); // if (computedStyles) { // allCSS += `/* 计算样式 */\n${computedStyles}\n\n`; // } return allCSS; } // 从样式表获取CSS文本 function getCSSFromStyleSheet(sheet) { try { // 如果是内联样式表 if (sheet.cssRules) { let cssText = ''; for (let j = 0; j < sheet.cssRules.length; j++) { cssText += sheet.cssRules[j].cssText + '\n'; } return cssText...
点击查看剩余70%