当前位置:首页 > JavaScript

js实现编辑

2026-02-01 10:45:25JavaScript

JavaScript 实现文本编辑功能

使用 contenteditable 属性可以让 HTML 元素变为可编辑状态。以下是一个简单的实现示例:

<div id="editor" contenteditable="true">点击这里开始编辑</div>

获取和设置编辑内容

通过 JavaScript 可以轻松获取和设置可编辑区域的内容:

const editor = document.getElementById('editor');

// 获取内容
const content = editor.innerHTML;

// 设置内容
editor.innerHTML = '<strong>新内容</strong>';

实现富文本编辑功能

使用 document.execCommand 可以实现基本的富文本编辑功能,虽然这个 API 已废弃,但在许多浏览器中仍然可用:

js实现编辑

function formatText(command, value = null) {
    document.execCommand(command, false, value);
}

现代替代方案

推荐使用更现代的库如 ProseMirrorTiptap 来实现富文本编辑:

import { Editor } from 'tiptap';

new Editor({
    element: document.getElementById('editor'),
    content: '<p>初始内容</p>',
});

处理编辑事件

监听输入事件可以实时获取编辑内容:

js实现编辑

editor.addEventListener('input', (e) => {
    console.log('内容已更改:', e.target.innerHTML);
});

保存编辑内容

可以将编辑内容保存到本地存储或发送到服务器:

function saveContent() {
    localStorage.setItem('editorContent', editor.innerHTML);
    // 或使用 fetch 发送到服务器
}

实现撤销/重做功能

维护一个编辑历史数组可以实现简单的撤销功能:

let history = [];
let historyIndex = -1;

editor.addEventListener('input', () => {
    history = history.slice(0, historyIndex + 1);
    history.push(editor.innerHTML);
    historyIndex++;
});

function undo() {
    if (historyIndex > 0) {
        historyIndex--;
        editor.innerHTML = history[historyIndex];
    }
}

标签: 编辑js
分享给朋友:

相关文章

js实现vue

js实现vue

Vue.js 简介 Vue.js 是一个渐进式 JavaScript 框架,用于构建用户界面。其核心库专注于视图层,易于与其他库或现有项目整合。 实现 Vue.js 的基本步骤 安装 Vue.j…

js实现打印

js实现打印

使用window.print()方法实现打印 在JavaScript中,可以通过调用window.print()方法直接触发浏览器的打印功能。这会打开系统的打印对话框,用户可以选择打印机和设置打印选项…

js实现目录

js实现目录

实现目录的基本思路 在JavaScript中实现目录功能通常涉及以下几个核心步骤:解析文档中的标题元素(如h1-h6),动态生成目录结构,并添加交互逻辑(如点击跳转)。以下是具体实现方法: 解析标题…

js节流实现

js节流实现

节流的概念 节流(Throttle)是一种限制函数执行频率的技术,确保函数在一定时间间隔内只执行一次。常用于滚动事件、窗口调整等高频触发的场景。 基础实现方法 使用时间戳判断是否执行函数:…

js计算器的实现

js计算器的实现

实现基础结构 HTML部分需要创建计算器的基本框架,包含显示区域和按钮。使用<div>容器包裹整个计算器,内部设置一个显示屏和多个按钮。 <div class="calculato…

js实现原理

js实现原理

JavaScript 实现原理 JavaScript 是一种解释型语言,其实现原理涉及多个核心组件和运行机制,包括引擎、运行时环境、事件循环等。 引擎与解释执行 现代 JavaScript 引擎(如…