新闻中心

html5使用contenteditable实现富文本编辑器 html5使用文本操作的API

2025-10-26
浏览次数:
返回列表
使用contenteditable属性可快速实现轻量级富文本编辑器,通过添加contenteditable="true"使元素可编辑,结合document.execCommand(已废弃但广泛支持)执行加粗、斜体、插入图片等格式化操作,并利用Selection与Range API精确控制选区内容,如高亮文本;监听input事件实时捕获内容变化,保存时存储innerHTML或innerText并注意XSS防护,适合自定义需求场景。

html5使用contenteditable实现富文本编辑器 html5使用文本操作的api

使用 contenteditable 属性结合 HTML5 提供的文本操作 API,可以快速实现一个轻量级富文本编辑器。这种方法无需引入大型框架或第三方库,适合自定义需求较强的场景。

启用 contenteditable 实现可编辑区域

在任意 HTML 元素上添加 contenteditable="true",即可让该元素内容变为可编辑状态。

<div id="editor" contenteditable="true" style="min-height: 200px; border: 1px solid #ccc; padding: 10px;">
    在这里输入内容...
</div>

浏览器会允许用户直接在这个 div 中输入、删除、格式化文本。默认支持基础的加粗、斜体、换行等行为,但要实现更复杂的格式控制,需要借助 J*aScript 和文档对象模型(DOM)操作。

使用 document.execCommand(已废弃但仍广泛支持)

虽然 document.execCommand 已被标记为过时,但在大多数现代浏览器中依然可用,是实现富文本格式控制的常用方式。

通过 execCommand 可执行如加粗、斜体、插入链接等命令:

  • document.execCommand('bold'):切换选中文本的加粗样式
  • document.execCommand('italic'):切换斜体
  • document.execCommand('insertImage', false, imageUrl):插入图片
  • document.execCommand('createLink', false, url):创建超链接
  • document.execCommand('formatBlock', false, '

    ')

    :将段落转为标题

示例按钮绑定加粗功能:

<button onclick="document.execCommand('bold')">加粗</button>

Selection 与 Range API 精确控制文本

对于更精细的操作,HTML5 提供了 SelectionRange 接口,可用于获取用户选中的文本范围并进行修改。

B2S商城系统 B2S商城系统

B2S商城系统B2S商城系统是由佳弗网络工作室凭借专业的技术、丰富的电子商务经验在第一时刻为最流行的分享式购物(或体验式购物)推出的开源程序。开发采用PHP+MYSQL数据库,独立编译模板、代码简洁、自由修改、安全高效、数据缓存等技术的应用,使其能在大浏览量的环境下快速稳定运行,切实节约网站成本,提升形象。注意:如果安装后页面打开出现找不到数据库等错误,请删除admin下的runtime文件夹和a

B2S商城系统 0 查看详情 B2S商城系统

常见用法包括:

  • window.getSelection():获取当前选中的 Selection 对象
  • selection.getRangeAt(0):获取选区对应的 Range
  • range.deleteContents():删除选中内容
  • range.insertNode(node):在选区插入节点
  • range.surroundContents(element):用某个元素包裹选中内容(注意边界限制)

例如,手动给选中文本添加红色背景:

function highlightText() {
  const selection = window.getSelection();
  if (selection.rangeCount === 0) return;
  const range = selection.getRangeAt(0);
  const span = document.createElement('span');
  span.style.backgroundColor = 'yellow';
  span.appendChild(range.extractContents());
  range.insertNode(span);
}

监听输入与保存内容

可通过监听 input 事件实时捕获编辑区域的变化:

document.getElementById('editor').addEventListener('input', function() {
  console.log('当前内容:', this.innerHTML);
});

保存数据时建议存储 innerHTMLinnerText,根据是否需要保留格式决定。注意防范 XSS 风险,对输出内容做适当过滤或转义。

基本上就这些核心要点。利用 contenteditable 搭配 execCommand 和 Selection/Range API,能构建出满足多数场景的富文本编辑器雏形,虽不复杂但容易忽略细节处理,比如光标位置维护和跨浏览器兼容性问题。后续可逐步扩展撤销、语法高亮、拖拽上传等功能。

以上就是html5使用contenteditable实现富文本编辑器 html5使用文本操作的API的详细内容,更多请关注其它相关文章!


# javascript  # 地图装饰画素材网站推广  # 嘉兴网站建设亅薇  # 辽宁网站建设优化排名  # 王通seo培训价格  # 台湾网站的优化策略  # 在这个  # 在这里  # 插入图片  # 游戏开发  # 转换工具  # 使用技巧  # 文档  # 自定义  # 加粗  # 编辑器  # win  # app  # 浏览器  # node  # html  # java  # html5  # 深圳餐饮网站建设  # 网站发帖推广平台怎么做  # 浙江seo查询打造  # seo优化网站怎样  # 宜昌个人网站推广公司 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 苹果手机如何防止被恶意App追踪  漫蛙manwa2最新登录网址_漫蛙manwa2手机网页版入口  React Hooks最佳实践:动态组件状态管理的组件化方案  Vue.js 图片显示异常排查:理解应用挂载范围与DOM ID唯一性  c++中的std::launder有什么实际用途_c++对象生命周期与指针优化  C++如何连接MySQL数据库_C++使用Connector/C++操作MySQL数据库教程  J*a中实现Go语言select通道多路复用机制  谷歌推RCS信息存档功能:公司可监控员工私密信息!  HTML长属性值处理:表单action路径优化与代码规范应对  4399网页游戏电脑版全新入口 4399电脑端在线玩指南  外媒分析《GTA6》定价:卖100美元可以但真没必要!  腾讯视频怎么举报不良内容_腾讯视频内容举报流程与违规信息处理方法  荣耀Play7TPro怎样在信息App置顶客服对话_iPhone荣耀Play7TPro信息App置顶客服对话【优先查看】  Safari浏览器输入栏卡顿如何解决 Safari搜索建议与缓存清理  在J*a中如何在J*a中使用异常机制记录错误日志_异常日志实践经验  Yandex搜索引擎一键访问入口_俄罗斯Yandex官网免登录  Tailwind CSS line-clamp 布局问题解析与修复指南  2026年CSGO开箱网站推荐 CSGO开箱平台精选  智慧团建扫码登录入口 智慧团建扫码登录入口官网版​  Windows7怎么硬盘安装 Windows7提取ISO镜像到非系统盘并运行setup.exe实现硬盘直装【教程】  TikTok搜索不到用户发布内容怎么办 TikTok用户内容搜索优化方法  css链接悬停下划线样式如何自定义_使用::after结合content和transition  XML中包含HTML标签导致解析错误? 正确嵌入非XML数据的两种方法  qq游戏大厅官方下载_qq游戏免费下载安装入口  Safari怎么安装扩展程序 浏览器插件安装与管理方法【详解】  2026春节假期时间安排 2026春节假日查询  邮政快递包裹最新位置 邮政快递实时追踪入口  TikTok评论显示延迟如何处理 TikTok评论刷新优化方法  微信客户端如何收红包_微信客户端接收红包使用教程  MAC如何安全彻底地删除文件_MAC使用终端命令确保文件无法被恢复  必由学官方登录入口 必由学教师学生账号快速访问  在J*a中如何使用BigDecimal进行高精度计算_BigDecimal类应用指南  蓝湖怎样用切图标注提对接效率_蓝湖用切图标注提对接效率【设计对接】  顺丰快递查询系统 官方正版查询入口  win11开机启动修复循环怎么办 Win11无法进入系统高级启动解决方法【修复】  Django通过AJAX异步上传图片并保存至模型的完整指南  React Router v6 教程:构建认证保护的私有路由与重定向策略  Python中如何避免重复条件判断:利用数据结构实现动态逻辑  NRF24L01数据传输深度解析:解决大载荷接收异常与分包策略  c++中的std::basic_string的SSO优化_c++短字符串优化深度解析  汽车之家官方网站官网入口_汽车之家网页版直接进入  理解J*aScript Promise的微任务队列与执行顺序  海棠账号登录入口_登录海棠账户同步阅读记录  mcjs网页版流畅运行 mcjs低配电脑畅玩入口  学习通在线学习平台 学习通网页版直接进入课程中心  AO3最新可访问网址 Archive of Our Own官方在线入口  Archive of Our Own官网直达 AO3最新可用地址一览  Golang如何优化CPU绑定任务分配策略_Golang CPU任务分配优化实践  Surface怎么安装系统 微软Surface Pro U盘重装win11教程  必由学网页版入口 必由学官方平台直接访问 

搜索