光标在Ace中是如何工作的
How does the cursor work in Ace
我对Ace的工作原理很感兴趣。
我很好奇光标是如何通过单击或按箭头键在div/span中的每个字符之间移动的。
我也很感兴趣的是,当你选择文本上的高亮显示时,它是如何工作的(在演示中有点变灰)
如果有人能对这些事情有所了解,我将不胜感激。
提前谢谢。
在Ace中,我基本上将DOM视为一个绘图API。您所看到的一切都是使用绝对定位的DIV和SPAN元素"绘制"的。使用SPAN绘制文本,线条(例如光标或选择)为DIV等。
为了正确定位所有东西,我首先测量一个字符的高度和宽度。这也是Ace只使用单间距字体的原因。
当您单击Ace内部时,我使用getBoundingClientRect计算鼠标在编辑器内部的相对位置,然后使用测量的字符大小将其转换为字符位置。使用键盘导航也是类似的。
当我检查演示页面并通过点击箭头键移动光标时,光标div的style.left属性在适当的方向上移动了7px。对于向上和向下,它是15px,即用于显示文本的跨度的确切大小。
对于选择,他们使用类名为ace_selection的div,然后将其放置在一个绝对位置。
我建议用chrome或firefox来检查这个演示以更仔细地了解它。你可以看到他们是如何创建新的div的,并在你采取的每一个操作中修改div的属性。
相关文章:
- Javascript:selenium Web驱动程序isDisplayed()不工作
- jQuery UI自动完成突然停止工作
- AngularJS UI路由器不能像ng路由器那样工作
- HTML5音频加载和播放获胜'我不能在iPad上工作
- JavaScript打印功能使日历停止工作
- Javascript.getHours()工作不正常
- 为什么这在IE中的工作方式与在Firefox中不同
- 视频HTML没有'无法在Internet Explorer 11上工作
- 扩展移相器按钮类不工作
- Firebase迁移-简单的Firebase.set没有'不再工作了——旧的还是新的
- 谷歌地图不是以HTML显示,而是在JS Fiddle上工作
- 正在尝试使用if和else添加类,但无法正常工作
- Jquery FadeIn FadeOut 只工作一次
- Foreach无法在Typescript中工作
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- 为什么不是't窗口.恢复正常工作吗?(javascript/jquery)
- 最大高度转换不;不工作,工作缓慢
- Gulp-rev:不是第一次工作,而是在第一次工作之后工作
- 在JavaScript中的类中,push和concat的工作方式有何不同
- JQuery - Ajax: encodeUriComponent不工作(EncodeUri工作)