CSS::contenteditable中元素的焦点

CSS::contenteditable中元素的焦点,第1张

CSS::contenteditable中元素的焦点

我想我找到了解决方案。

通过以下代码片段,您可以在选择更改时将父元素置于当前插入符号位置。

var selectedElement = null;function setFocus(e) {  if (selectedElement)    selectedElement.style.outline = 'none';  selectedElement = window.getSelection().focusNode.parentNode;  // walk up the DOM tree until the parent node is contentEditable  while (selectedElement.parentNode.contentEditable != 'true') {    selectedElement = selectedElement.parentNode;  }  selectedElement.style.outline = '1px solid #f00';};document.onkeyup = setFocus;document.onmouseup = setFocus;

在这里,我

outline
手动更改属性,但是您当然可以添加类属性,并通过CSS设置样式。

您仍然必须手动检查该属性是否

selectedElement
是我们的子级。但我认为您可以掌握基本思路。
<div>``contenteditable

编辑:我更新了代码以及JSFiddle,使其也可以在Firefox和Internet Explorer9+中使用。不幸的是,这些浏览器没有

onselectionchange
事件处理程序,因此我不得不使用
onkeyup
onmouseup



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5112052.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-17
下一篇 2022-11-17

发表评论

登录后才能评论

评论列表(0条)

保存