使用javascript自定义Contenteditable行为

目前在Firefox下,当我在一个令人满意的段落中按回车时,它插入一个br标签创建一个新的段落标签,然后将一个br标签放在该新段落中.我想修改这样的行为

> Shift enter = br tag(这已经是认值)

>输入重复的当前元素是p,li,h1..etc并删除任何尾随或前导(W3C规范需要一些我可以使用的事件,但我完全不确定如何实现它们.
>元素开头的退格键会将它与前面的兄弟元素合并(如果存在)
>元素末尾的删除会将其与以下兄弟(如果存在)合并.

我试过捕获按键并检查返回,删除和退格键,但我似乎无法准确获取当前的插入位置或者如果我覆盖它则阻止认行为.

如果有人在那里知道如何…我会发现它最有帮助

>在一个令人满意的段落中获取和/或设置当前插入位置.
>防止contenteditable的认行为
>附上W3C建议所要求的活动. http://www.w3.org/TR/DOM-Level-2-Events/events.html#Events-eventgroupings-mutationevents

也许有人甚至知道已经以这种方式行事的用户代理(浏览器).这是可以接受的.

谢谢,

丹尼尔

解决方法

要编辑内容可编辑的行为,我会这样做:
$("#editable").bind("keypress",function(e){
   if(e.keyCode==13 && e.shiftKey){ //enter && shift
      e.preventDefault(); //Prevent default browser behavior
      this.html(this.html+"<br>");
   }
});

你可以编辑html函数里面的内容. PS:我不记得jQuery是否在事件对象上有shiftKey和keyCode …如果出现任何问题,请将e更改为e.originalEvent.

得到carret的位置:
在非IE中:

document.getSelection().anchorOffset

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...