博客
关于我
div可编辑user-modify/contenteditable
阅读量:781 次
发布时间:2019-03-24

本文共 788 字,大约阅读时间需要 2 分钟。

在网页开发中,我们经常需要对div元素的内容进行编辑。过去,很多开发者推荐使用user-modify属性来实现这一需求。例如,Google支持-webkit-read-modify,Firefox则支持-moz-user-modify。然而,这些方法的效果在各大厂商之间存在差异。因此,了解这些属性的最新支持状态至关重要。

参考张新旭的文章用户行为可修改性详解可以获得关于user-modify的深入解析。然而,需注意该文章发布的时间已较久,可能不能完全反映现状。根据MDN的最新信息,user-modify属性已经不再推荐使用,并被替代为更为现代的技术。

在此,推荐使用HTML5中的contenteditable属性。它是一个全局属性,接受truefalse两种值,默认值为falsetrue表示元素内容可编辑,false表示只读状态。这种属性的好处在于其广泛的浏览器支持,所有主流浏览器都已实现。

需要注意的是,contenteditable的行为与其他浏览器的实现略有不同。例如,某些浏览器可能默认不支持插入图片或格式化文本,此时可以通过设置contenteditable=plaintext-only来限制仅允许纯文本输入。这种方法能够实现更精确的文本处理需求。

实现上,当contenteditable设为false时,元素仅显示纯文本。当需要编辑时,可以通过双击或触发 JS 脚本将状态切换为true。但需注意,即使用户在contenteditable=true状态下粘贴内容,切换回false时仍会保留原有格式。这一点在实际应用中需要特别注意布局和样式设计。

在实际开发中,建议合理选择基于任务的innerHTML修改方法。通过小心设置contenteditable属性或利用创建内容editable的补丁,可以在保持可读性和安全性的同时实现文本编辑功能。

转载地址:http://dcwuk.baihongyu.com/

你可能感兴趣的文章
Node-RED中通过node-red-ui-webcam节点实现访问摄像头并截取照片预览
查看>>
Node-RED安装图形化节点dashboard实现订阅mqtt主题并在仪表盘中显示温度
查看>>
Node-RED订阅MQTT主题并调试数据
查看>>
node-request模块
查看>>
Node.js 8 中的 util.promisify的详解
查看>>
node.js url模块
查看>>
Node.js Web 模块的各种用法和常见场景
查看>>
Node.js 函数是什么样的?
查看>>
Node.js 切近实战(七) 之Excel在线(文件&文件组)
查看>>
node.js 初体验
查看>>
Node.js 历史
查看>>
Node.js 在个推的微服务实践:基于容器的一站式命令行工具链
查看>>
Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
查看>>
Node.js 异步模式浅析
查看>>
node.js 怎么新建一个站点端口
查看>>
Node.js 文件系统的各种用法和常见场景
查看>>
Node.js 模块系统的原理、使用方式和一些常见的应用场景
查看>>
Node.js 的事件循环(Event Loop)详解
查看>>
node.js 简易聊天室
查看>>
Node.js 线程你理解的可能是错的
查看>>