div contenteditable?documents安卓版下载
大家好,今天小编来为大家解答以下的问题,关于div contenteditable,documents安卓版下载这个很多人还不知道,现在让我们一起来看看吧!
如何让contenteditable元素只能输入纯文本 00 张鑫旭
一、温故而知新
很多年以前,稍等,让我搜一下contenteditable(右上角),哈,是2010年的时候,写了篇文章“div模拟textarea文本域轻松实现高度自适应”,就是说的contenteditable的应用。
虽然说,利用全浏览器都支持的contenteditable模拟文本域可以实现体验相当不错的高度跟随内容自动撑开的效果,但是呢,有个很大的问题就是HTML内容可以直接被粘贴进去,如下图所示:
之前的文章提到过过滤HTML的方法,保证内容都是纯文本。然而,这种方法的问题在于:
粘贴完毕到过滤结束有时间差,用户很看到内容一闪而过的糟糕体验;
光标的位置会发生变化,不是之前focus的位置了;
当年的我图样图森破,所以,只有上面这种程度。实际上,控制contenteditable元素只能输入纯文本是有体验比较好的方法的。
二、与contenteditable属性无关的CSS控制法
一个div元素,要让其可编辑,也就是可读写,contenteditable属性是最常用方法,做前端的基本上都知道。但是,知道CSS中有属性可以让普通元素可读写的的同学怕是就少多了。
主角亮相:user-modify.
支持属性值如下:
user-modify: read-only;
user-modify: read-write;
user-modify: write-only;
user-modify: read-write-plaintext-only;
其中,write-only不用在意,当下这个年代,基本上没有浏览器支持,以后估计也不会有。read-only表示只读,就是普通元素的默认状态啦。然后,read-write和read-write-plaintext-only会让元素表现得像个文本域一样,可以focus以及输入内容。
您可以狠狠地点击这里:CSS user-modify属性行为表现demo
会发现,设置了read-write和read-write-plaintext-only值的两个<p>标签元素是可以被focus的:
而这两者的区别就在于,一个可以输入富文本,而下面一个只能输入纯文本,例如,我们从某网页同时复制一段内容粘贴进去看看:
好了,至此,本文标题的答案实际上就已经有了。也就是给元素设置:
user-modify: read-write-plaintext-only
就可以让元素既可以编辑,也只能输入纯文本,表现得就跟textarea文本域一样。
是不是很酷啊!然而,抱歉地跟大家讲下,目前只有webkit内核浏览器才支持read-write-plaintext-only这个值,因此,我们的使用其实是:
-webkit-user-modify: read-write-plaintext-only
我们可以在移动端使用,以及,只需要兼顾webkit内容的桌面网页项目。
三、使用标准contenteditable属性值的HTML控制法
咳咳,提问:在HTML中,contenteditable支持的属性值是?
图样图森破时候的我,脑中就只有contenteditable="true"和contenteditable="false",科科,后来我发现自己太天真了,新的草案中明确表示还有多个其他属性值:
The contenteditable attribute is an enumerated attribute
whose keywords are the empty string(“”),“events”,“caret”,“typing”,
“plaintext-only”,“true”, and“false”. There is one additional state,
the inherit state, which is the missing value default(and the invalid
value default).
垂直展示下就是(不包括默认的inherit继承):
contenteditable=""
contenteditable="events"
contenteditable="caret"
contenteditable="plaintext-only"
contenteditable="true"
contenteditable="false"
别问我,我也不知道"events"和"caret"是干什么用的,嘿,但是"plaintext-only"我是知道的,可以让编辑区域只能键入纯文本。这里就不需要demo了,直接下面的框框,大家可以试试,看看能不能搞富文本。
<div contenteditable="plaintext-only"></div>
如果您发现,居然出乎意料,可以弄进去富文本,那说明你使用的是非Chrome之流的浏览器。
换句话说,contenteditable="plaintext-only"和CSS只的-webkit-user-modify: read-write-plaintext-only一样,目前仅仅是Chrome浏览器支持比较好的。
所以,您的项目如果还有很多IE8浏览器的用户,我只能替你惋惜,美妙的东西无法立即用上,不得已,寻求下面的方法。
四、控制粘贴paste事件的JS控制法
如果我们单纯地敲击键盘,输入的内容实际上都是纯文本。除了一些特殊情况,例如IE浏览器下的编辑框会自动把合乎条件的url地址自动加上链接。富
文本污染的情况主要出现在复制粘贴的时候,于是,如果我们能在粘贴的时候,对剪切板中的内容进行HTML过滤,再手动插入内容,岂不就可以完美解决无法输
入富文本的问题了吗
如何使用 contenteditable 属性实现输入框自动伸缩并换行
要使用 contenteditable属性实现输入框自动伸缩并换行,可通过以下步骤完成,结合 HTML结构、CSS样式及属性配置实现动态文本调整。
核心实现步骤创建可编辑的 div元素使用 contenteditable="true"将 div标记为可编辑区域,用户可直接输入或修改内容。
<div class="auto-expand" contenteditable="true"></div>设置 CSS样式通过以下样式控制文本的自动换行与容器伸缩:
display: inline-block(或 inline):允许元素在文本流中呈行内显示,同时支持宽度自适应。
word-break: break-all:强制在任意字符间断行,避免长单词或连续字符溢出。
word-wrap: break-word:在单词边界断行,优先保持单词完整。
min-width/max-width:可选,限制容器的最小/最大宽度。
border/padding:可选,用于可视化边界或调整内边距。
.auto-expand{ display: inline-block;/*或 inline,根据布局需求选择*/ word-break: break-all; word-wrap: break-word; min-width: 100px;/*可选:设置最小宽度*/ max-width: 300px;/*可选:设置最大宽度*/ border: 1px solid#ccc;/*演示用边框*/ padding: 5px;/*演示用内边距*/}嵌入到上下文中(可选)若需将可编辑区域嵌入到固定文本中(如示例中的“你好”和“请下午来开会”),需通过外层容器包裹,并确保可编辑 div的 display属性与上下文兼容。
<div class="input-container">你好,<div class="auto-expand" contenteditable="true">1111111111111111111111111111111111111111111</div>请下午来开会。</div>关键原理说明contenteditable属性:将普通 div转换为可交互的输入区域,支持文本输入、删除、粘贴等操作。自动换行机制:word-break: break-all:强制断行,适用于无空格的长字符串(如 URL、连续数字)。
word-wrap: break-word:在单词间断行,优先保持语义完整性。
两者结合可覆盖大多数换行场景。
动态伸缩:通过 display: inline-block或 inline,容器宽度会随内容增加而扩展,直至达到 max-width限制(若设置)。完整示例代码<!DOCTYPE html><html><head><style>.auto-expand{ display: inline-block; word-break: break-all; word-wrap: break-word; min-width: 100px; max-width: 300px; border: 1px solid#ccc; padding: 5px; margin: 5px 0;}.input-container{ font-family: Arial, sans-serif; line-height: 1.5;}</style></head><body><div class="input-container">你好,<div class="auto-expand" contenteditable="true">输入内容会自动换行并调整宽度...</div>请下午来开会。</div></body></html>效果验证输入长文本时,容器宽度会动态扩展,超出 max-width后自动换行。连续字符(如 1111111111)会被 word-break: break-all强制断行。普通文本(如英文单词)会优先在空格处换行(word-wrap: break-word)。注意事项布局兼容性:若外层容器为 flex或 grid,需调整 display属性(如改用 block)。移动端适配:建议添加-webkit-user-select: text确保移动端可正常输入。样式隔离:避免全局样式(如*{ word-break: break-all})干扰可编辑区域的行为。通过上述方法,可高效实现基于 contenteditable的自动伸缩换行输入框,适用于评论框、富文本编辑器等场景。
元素为contenteditable时,内容为空,光标显示异常
问题可能由元素为空、嵌套不可编辑元素、浏览器兼容性等原因导致,以下是解决办法:
空内容时光标不显示元素内插入 (非换行空格),如<div contenteditable="true"> </div>。通过 CSS确保最小高度,如.editable{ min-height: 20px;}。嵌套不可编辑元素后光标异常在不可编辑元素后添加<br>或 ,如<div contenteditable="true"><span contenteditable="false">固定文本</span> </div>。通过 JavaScript控制光标位置,点击不可编辑元素时将光标移至末尾。浏览器兼容性差异Firefox删除含 contenteditable="false"的元素时需额外处理,可通过 JS监听删除事件。Chrome默认允许删除不可编辑元素,但光标定位可能偏移,需通过 getSelection()手动调整。其他优化建议使用 contenteditable="plaintext-only"(部分浏览器支持)限制纯文本输入,减少格式混乱。避免空标签嵌套,确保初始内容非空,可插入空格或换行。结合 CSS隐藏默认聚焦轮廓,如.editable:focus{ outline: none;}。设置 placeholder,通过 CSS:empty伪类模拟占位符。清除多余标签,用 JS过滤删除时残留的<br>标签。重置后光标定位,清空内容后,通过 Range和 Selection API将光标定位到末尾。聚焦时强制显示光标,确保元素获得焦点时光标可见。
文章到此结束,如果本次分享的div contenteditable和documents安卓版下载的问题解决了您的问题,那么我们由衷的感到高兴!