vue开发常用css,js 篇2(持续更新)

vue开发常用css,js 篇1已完结了,总共有37个知识点,有需要的小伙伴可以点击链接跳转过去

目录标题

      • [1、contenteditable 属性的标签中获取光标的位置](#1、contenteditable 属性的标签中获取光标的位置)

1、contenteditable 属性的标签中获取光标的位置

篇1中第37个点,也是实现这个问题,但是比较复杂,所以优化迭代了一版,现在一起来看看吧

直接获取 innerHtml 中range.startContainer.data 的位置 ,加上startOffset 的位置即可获取位置

javascript 复制代码
export function getCursorPosition(domId) {
  var cursorPos = 0;
  var selection = window.getSelection();
  const el = document.getElementById(domId);
  let htmlChars = el.innerHTML;
  cursorPos = selection.focusOffset;
  if (selection.rangeCount > 0) {
    const range = selection.getRangeAt(0);
    let pos = htmlChars.indexOf(range.startContainer.data);
    cursorPos = pos + range.startOffset;
  }
  console.log("光标位置:", cursorPos);
  return splitHtmlStringAtPosition(el.innerHTML, cursorPos);
}
export function splitHtmlStringAtPosition(inputString, position) {
  return [inputString.slice(0, position), inputString.slice(position)];
}
相关推荐
小old弟1 分钟前
深入详解vue中的优化手段:路由的懒加载
前端·vue.js
puppy0_03 分钟前
【万字长文】前端如何处理计算密集型操作(数据量10w+)
前端·javascript
acheding11 分钟前
Vue + CSS实现渐变栅格进度条
前端·css·vue.js·数据可视化
Sailing22 分钟前
递归陷阱:如何优雅地递归获取数据?别让你的微前端卡死!
前端·javascript·面试
前端大卫38 分钟前
【Chrome 官方示例】🔥手把手教你解锁 Performace 选项卡
前端·javascript·性能优化
苏州第一深情41 分钟前
SpeechSynthesisUtterance文字语音播报, 循环播报, 方法封装多组件使用, 自定义播报音色音量音调
前端·javascript·vue.js
JiangJiang44 分钟前
Vue3源码:5个问题带你读懂watch
javascript·vue.js·面试
openInula前端开源社区1 小时前
【openInula茶话会】第一期:前端框架openInula整体介绍
前端·vue.js
如此风景1 小时前
TypeScript中的Record
javascript
前端九哥1 小时前
vue3实现复制到剪切板
前端·vue.js