成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何僅用JavaScript實現實時協作文本編輯器

開發 前端
我不想用Firebase,不想碰Node.js,更不想搞Redis發布訂閱或CRDT數據庫。我只要兩個瀏覽器標簽頁——哪怕在不同設備上——能同時編輯同一份文檔,并神奇地同步變更。

你沒看錯。我開發了一款類似Google Docs的協作編輯器,能夠實時同步多瀏覽器端的編輯內容——完全基于JavaScript實現,無需服務器后端、不依賴WebSocket、零框架加持。這聽起來像魔法,但背后的核心技術是被低估的WebRTC。

1. 為什么選擇無后端實時編輯器

你是否也曾有過那種"理論上行不通但就是念念不忘"的想法?我的執念是:

「"能否僅用純JavaScript打造類似Google Docs的編輯器...完全不需要后端?"」

我不想用Firebase,不想碰Node.js,更不想搞Redis發布訂閱或CRDT數據庫。我只要兩個瀏覽器標簽頁——哪怕在不同設備上——能同時編輯同一份文檔,并神奇地同步變更。

最終發現,WebRTC + BroadcastChannel + 操作轉換(OT) 就是完美解決方案。

2. 架構設計:如何實現無服務器同步?

我的架構方案如下:

┌────────────┐ BroadcastChannel ┌────────────┐  
│ 標簽頁A   │ ─────────────────────────? │ 標簽頁B   │  
│ localhost  │ ?───────────────────────── │ localhost  │  
└────────────┘                         └────────────┘
        ?                                       ?
     WebRTC                                WebRTC
        ?                                       ?
     終端A  <──────────────────────────> 終端B

核心技術組件:

  • WebRTC:實現跨設備的點對點連接
  • BroadcastChannel:同步同一設備不同標簽頁的編輯
  • 操作轉換(OT):解決編輯沖突問題

最神奇的是——只要允許WebRTC使用不安全源(或用Python的http.server托管)——這套方案甚至能在file://協議下運行。

3. 搭建基礎文本編輯器

從最簡單的HTML+JavaScript編輯器開始:

<textarea id="editor" rows="20" cols="80">你好,世界!</textarea>
<script>
const editor = document.getElementById("editor");
</script>

添加變更監聽和廣播功能:

editor.addEventListener("input", () => {
  const content = editor.value;
  broadcastChange(content);
});

4. 通過BroadcastChannel實現標簽頁同步

這是最簡單的同步方案:

const channel = new BroadcastChannel("collab_editor");

function broadcastChange(content) {
  channel.postMessage({ type: "update", content });
}

channel.onmessage = (e) => {
  if (e.data.type === "update") {
    editor.value = e.data.content;
  }
};

現在打開兩個標簽頁,一處修改會實時同步到另一處——完全無需后端支持。??

但僅限于同設備,接下來我們要實現跨設備同步。

5. 通過WebRTC連接遠程瀏覽器

WebRTC讓瀏覽器直接通信(經過簡短的信號交換后無需服務器中轉)。我們使用零依賴的simple-peer庫:

<script src="https://unpkg.com/simple-peer/simplepeer.min.js"></script>

let peer = newSimplePeer({
initiator: location.hash === "#host",
trickle: false
});

peer.on("signal", data => {
document.getElementById("signal").value = JSON.stringify(data);
});

document.getElementById("connect").onclick = () => {
let remoteData = JSON.parse(document.getElementById("remote").value);
  peer.signal(remoteData);
};

peer.on("connect", () => {
console.log("?? 遠程連接成功!");
});

peer.on("data", data => {
let msg = JSON.parse(data);
if (msg.type === "update") {
    editor.value = msg.content;
  }
});

functionbroadcastChange(content) {
if (peer.connected) {
    peer.send(JSON.stringify({ type: "update", content }));
  }
}

添加信號交換UI:

<textarea id="signal" placeholder="你的信號數據"></textarea>
<textarea id="remote" placeholder="粘貼對方的信號數據"></textarea>
<button id="connect">連接</button>

現在設備A將信號數據發給設備B,點擊連接——編輯內容就能通過互聯網同步了,全程無需服務器。

6. 使用操作轉換解決編輯沖突

當兩人同時編輯時會出現覆蓋問題,我們需要實時合并修改。這就是**操作轉換(OT)**的價值:

<script src="https://unpkg.com/ot/lib/ot.min.js"></script>

let doc = new ot.Document(editor.value);

editor.addEventListener("input", () => {
const oldValue = doc.text;
const newValue = editor.value;

const operation = ot.TextOperation.fromDiff(oldValue, newValue);
  doc = doc.apply(operation);

const message = JSON.stringify({ 
    type: "ot", 
    operation: operation.toJSON() 
  });
  peer.send(message);
});

peer.on("data", data => {
let msg = JSON.parse(data);
if (msg.type === "ot") {
    const op = ot.TextOperation.fromJSON(msg.operation);
    doc = doc.apply(op);
    editor.value = doc.text;
  }
});

現在編輯操作會智能合并,而非簡單覆蓋,實現了完整的并發控制。

7. 通過LocalStorage實現自動保存

為防止內容丟失,添加簡易自動保存:

setInterval(() => {
  localStorage.setItem("autosave", editor.value);
}, 1000);

window.onload = () => {
  const saved = localStorage.getItem("autosave");
  if (saved) editor.value = saved;
};

雖然簡陋,但免費且支持離線工作。

8. 單文件部署方案

整個應用——包含文本編輯器、P2P網絡、自動保存和并發控制——只需單個HTML文件:

editor.html  # 在多個標簽頁或設備中打開即可

可部署在任何平臺:GitHub Pages、Netlify,甚至python3 -m http.server

沒有后端、無需數據庫、零月租費用。

反思:這改變了我的協作工具開發觀

曾經我以為實時應用必須依賴Firebase、復雜的WebSocket邏輯或分布式系統專家。但這次實踐讓我明白:

「現代瀏覽器的能力令人震驚,而大多數開發者只觸及了皮毛」

僅用原生JavaScript,你就能打造媲美Google Docs的實時協作應用。這套方案現已應用在我的結對編程工具、實時代碼審查面板甚至AI代理調試器中。

進階建議:若想達到Google Docs級別,可添加:

  • 通過contentEditable實現富文本編輯
  • position元數據顯示協作者光標
  • WebRTC失敗時的云端回退方案
  • 通過Yjs或Automerge實現CRDT支持

稍加擴展,你的周末項目就能達到生產級水準。

原文鏈接:https://medium.com/javascript-in-plain-english/how-i-built-a-real-time-collaborative-text-editor-using-javascript-and-no-backend-f76190efee6e 作者:Suleman safdar

責任編輯:武曉燕 來源: 前度小石匠
相關推薦

2017-11-16 17:35:13

GitHub文本編輯代碼

2018-01-05 14:48:03

前端JavaScript富文本編輯器

2020-12-23 22:25:11

Vi文本編輯器Unix

2010-03-24 09:20:07

CentOS vi編輯

2021-01-07 11:00:59

Sed文本編輯器Linux

2022-05-13 15:32:11

GNOME文本編輯器

2020-12-29 06:34:55

KDE Plasma文本編輯器

2017-07-27 20:21:06

iOSUITableView富文本編輯器

2023-04-17 11:03:52

富文本編輯器MTE

2023-05-11 07:34:36

Yjs協同編輯

2021-01-03 16:57:43

heredoc文本編輯器Linux

2016-09-23 20:30:54

Javascriptuiwebview富文本編輯器

2011-05-11 10:27:42

文本編輯器

2013-11-18 10:08:56

工具免費編程工具

2009-12-09 10:27:03

VS 2005文本編輯

2012-09-29 11:38:27

編程工具文本編輯器編程

2022-01-18 09:35:36

GNOME編輯器Linux

2015-06-26 11:11:50

GitHub Ato文本編輯器

2014-06-05 10:34:54

Notepad++

2012-04-11 10:35:22

jEditorJava
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩另类 | 久久精品国产99国产 | 亚洲综合三区 | 一本一道久久a久久精品蜜桃 | 亚洲精品丝袜日韩 | 涩涩视频网站在线观看 | 色综合激情 | www.99精品 | 精品视频一区在线 | 夜久久 | 精品国产一区二区在线 | 人人澡人人射 | 午夜免费电影院 | 日韩精品一区二区三区视频播放 | 日韩av成人在线 | 国产精品久久久 | 日本网站免费观看 | 日韩高清成人 | 日本一区二区三区免费观看 | 亚州综合在线 | 国产日韩精品一区二区 | 91色在线视频 | 成人av影院 | 一本大道久久a久久精二百 欧洲一区二区三区 | 自拍偷拍第一页 | 国产 日韩 欧美 制服 另类 | av大片在线 | 亚洲高清视频在线观看 | 91小视频| 国产欧美久久精品 | 日日噜噜夜夜爽爽狠狠 | 亚洲高清在线观看 | 亚洲精品久久嫩草网站秘色 | 极情综合网 | av在线成人 | 久久久婷 | 亚洲一区二区三区欧美 | 婷婷色成人 | 国产精品欧美一区二区三区 | 成人精品鲁一区一区二区 | 久久一二区 |