2025-05-05 22
在我们日常工作中,可能会遇到截图页面的场景,有时页面有些内容不符合要求,我们可能需要进行一些数值或内容的修改。如果你会 PS,修改内容难度不高,如果你是前端,打开控制台也能通过修改 dom 的方式进行简单的文字修改。
分享一个冷门又实用的前端技巧 —— 只需一行 JavaScript 代码,「让任何网页瞬间变成可编辑的!甚至,还可以插入图片等媒体内容。
很难想象,这么炫酷的功能,居然只需要在控制台输入一条指令:document.designMode = "on";
打开浏览器控制台(F12),复制粘贴这行代码,回车即可。
我们也能实现 Iframe 嵌套页面的编辑:iframeNode.contentDocument.designMode = "on";
如果你想关闭此功能,输入document.designMode = "off"
即可。
Document:designMode 属性
MDN 是这样介绍的:document.designMode 控制整个文档是否可编辑。有效值为 "on" 和 "off"。根据规范,该属性默认为 "off"。
Firefox 遵循这一标准。早期版本的 Chrome 和 IE 默认为 "inherit"。从 Chrome 43 开始,默认为 "off" 并不再支持 "inherit"。在 IE6-10 中,该值为大写。兼容性方面,基本上所有浏览器都是支持的。
与 designMode 关联的 API 其实还有 contentEditable 和 execCommand(已弃用,但部分浏览器还可以使用)。
contentEditable与designMode功能类似,不过contentEditable可以使特定的 DOM 元素变为可编辑,而designMode只能使整个文档可编辑。
contentEditable | document.designMode | |
---|---|---|
true 或 false | document.designMode = "on" | |
<div> , <span> 等 | ||