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)];
}
相关推荐
LCG元11 分钟前
Vue.js组件开发-实现广告图片浮动随屏幕滚动
前端·javascript·vue.js
_未知_开摆37 分钟前
el-table表格点击单元格实现编辑
前端·javascript·vue.js·elementui
_island2 小时前
《Cursor-AI编程》基础篇-Tab代码智能补充
前端·javascript·aigc
大模型铲屎官3 小时前
前端表单验证终极指南:HTML5 内置验证 + JavaScript 自定义校验
前端·javascript·html·html5·表单验证·内置验证·自定义校验
lbh5 小时前
Vue 3 vs React 18:设计理念与开发体验对比
前端·vue.js·react.js
林涧泣5 小时前
【Uniapp-Vue3】iconfont图标库的使用
前端·javascript·uni-app
烛.照1035 小时前
Vue整合Axios
前端·vue.js·chrome
陈钇钇6 小时前
问deepseek,如何看待ai降低学习成本而导致软件开发岗位需求降低,和工资下降。 软件从业人员何去何从?
vue.js
工业互联网专业6 小时前
基于springboot+vue的健身房管理系统
java·vue.js·spring boot·毕业设计·源码·课程设计
慕斯-ing11 小时前
Vue指令v-on
前端·vue.js·经验分享