精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何僅用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編輯

2020-12-29 06:34:55

KDE Plasma文本編輯器

2021-01-07 11:00:59

Sed文本編輯器Linux

2022-05-13 15:32:11

GNOME文本編輯器

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

2013-11-18 10:08:56

工具免費編程工具

2016-09-23 20:30:54

Javascriptuiwebview富文本編輯器

2011-05-11 10:27:42

文本編輯器

2009-12-09 10:27:03

VS 2005文本編輯

2015-06-26 11:11:50

GitHub Ato文本編輯器

2014-06-05 10:34:54

Notepad++

2022-01-18 09:35:36

GNOME編輯器Linux

2012-09-29 11:38:27

編程工具文本編輯器編程

2012-04-11 10:35:22

jEditorJava
點贊
收藏

51CTO技術棧公眾號

高清免费电影在线观看| 波多野结衣视频网址| 国产免费av国片精品草莓男男| 国产精品午夜久久| 91久久久国产精品| 精品一级少妇久久久久久久| 日韩高清三区| 欧美色视频一区| 欧美精品久久96人妻无码| 俄罗斯嫩小性bbwbbw| 午夜亚洲性色视频| 精品国产一区二区在线| 黄色激情在线观看| 色猫猫成人app| 亚洲色图都市小说| 极品校花啪啪激情久久| 在线观看视频中文字幕| 欧美日本一区二区视频在线观看 | 亚洲香蕉av在线一区二区三区| 日韩av卡一卡二| 91探花在线观看| 国产蜜臀av在线一区二区三区| 亚洲精品免费av| 中文字幕超碰在线| 牛夜精品久久久久久久99黑人| 日韩精品视频免费专区在线播放| 黄色三级视频在线播放| 台湾佬成人网| 无码av免费一区二区三区试看| 亚洲精品免费在线看| 午夜黄色小视频| 国产精品小仙女| 国产精品久久久久9999| 欧美成人aaaaⅴ片在线看| 99热精品久久| 一本一本久久a久久精品牛牛影视 一本色道久久综合亚洲精品小说 一本色道久久综合狠狠躁篇怎么玩 | 成人在线播放免费观看| 国产午夜精品一区二区| 国产一区二区免费在线观看| 国产精品毛片一区视频播| 久久免费国产| 91精品国产91久久久久久吃药| 天堂网avav| 成人91在线| 精品中文视频在线| japanese在线观看| 欧美高清一级片| 欧美美女黄视频| 青青青国产在线视频| 妞干网免费在线视频| 亚洲综合色视频| 宅男噜噜99国产精品观看免费| 九九九伊在人线综合| 成人午夜私人影院| 成人久久18免费网站漫画| 91激情在线观看| 麻豆国产精品官网| 国产精品视频99| 波多野结衣在线观看视频| 综合精品久久| 日韩精品视频免费专区在线播放| 精品人妻一区二区三区日产| ccyy激情综合| 亚洲高清福利视频| 影音先锋黄色资源| 琪琪久久久久日韩精品| 日韩福利在线播放| 三级男人添奶爽爽爽视频| 欧美日韩导航| 亚洲精品一区二区三区不| 97伦伦午夜电影理伦片| 红桃成人av在线播放| 在线观看不卡av| 免费在线观看a视频| 成人网18免费网站| 日韩视频免费观看| 欧美日韩国产精品综合| 亚洲乱亚洲高清| 欧美在线视频播放| 久久永久免费视频| 久久99精品国产91久久来源| 亚洲综合最新在线| 女人18毛片水真多18精品| 成人免费视频caoporn| 久久久99爱| 国产高清自拍视频在线观看| 国产精品美女视频| 国产日韩第一页| av中文字幕电影在线看| 色综合久久久久综合99| 成 人 黄 色 小说网站 s色| 国产美女精品视频免费播放软件| 精品国精品国产| 性久久久久久久久久| 欧美精品色图| 色综合久久中文字幕综合网小说| 国产午夜久久久| 首页国产欧美日韩丝袜| 91系列在线观看| 四虎永久在线精品免费网址| 久久精品网站免费观看| 亚洲精品国产一区| 伦理av在线| 日本精品视频一区二区三区| 亚洲免费成人在线视频| 美女主播精品视频一二三四| 一区二区在线免费视频| 青娱乐国产精品| 亚洲欧美日本国产专区一区| 国产精品夜间视频香蕉| 国精品人妻无码一区二区三区喝尿| 久久久久久亚洲综合| 中文字幕精品在线播放| 欧洲一区二区三区精品| 日韩一区二区精品在线观看| 丰满少妇在线观看资源站| 99精品美女| 欧美性视频精品| 精品国产18久久久久久| 国产女人aaa级久久久级| 成人免费观看在线| 欧美97人人模人人爽人人喊视频| 亚洲国产精品网站| 男人的天堂久久久| 欧美aaaaa成人免费观看视频| 国产二区不卡| 免费超碰在线| 色老汉av一区二区三区| 亚洲一区二区三区黄色| 久久久人成影片免费观看| 国产98色在线| 天堂在线观看免费视频| 一区二区三区精品视频在线| 色婷婷综合网站| 久久不见久久见中文字幕免费| 久久99精品久久久久久青青91| 伊人久久亚洲综合| 国产午夜精品在线观看| 鲁一鲁一鲁一鲁一澡| 91精品丝袜国产高跟在线| 久久久国产精品x99av| 中文字幕 国产精品| 91丨九色丨蝌蚪丨老版| 黄色大片中文字幕| 久久99成人| 久久九九亚洲综合| 一级黄色片在线观看| 欧美经典三级视频一区二区三区| 女人和拘做爰正片视频| h视频久久久| 欧美高跟鞋交xxxxhd| 精品国自产拍在线观看| 自拍视频在线观看一区二区| 国产色视频在线播放| 成人黄色小视频| 国产精品美女久久久久久免费| 国产三级电影在线| 欧美日韩一区二区三区在线看| 少妇人妻好深好紧精品无码| 日韩在线一区二区三区| 日韩伦理一区二区三区av在线| 日韩电影免费观| 亚洲人永久免费| 日本欧美www| 国产精品嫩草影院av蜜臀| 高清av免费看| 五月久久久综合一区二区小说| 国产欧美一区二区三区久久人妖 | 亚洲深夜福利在线| 日本免费精品视频| 国产精品美女www爽爽爽| 日本中文字幕精品—区二区| 999久久久亚洲| 亚洲xxxxx电影| 羞羞视频在线观看不卡| 亚洲精品在线免费播放| 天堂在线免费观看视频| 亚洲国产精华液网站w| 成人综合久久网| 黄色一区二区三区四区| 精品国产区在线| 一区在线影院| 欧美xxxx18国产| 无码国产精品一区二区免费16| 日韩欧亚中文在线| 69夜色精品国产69乱| 成人性视频免费网站| 国内外成人激情视频| 欧美一站二站| 51国偷自产一区二区三区| 免费影视亚洲| 日韩电影免费观看在线观看| 中文字幕乱码中文字幕| 亚洲一区二区三区在线播放| 成人免费毛片糖心| 国产一区二区三区久久悠悠色av| 日韩国产欧美亚洲| 日韩一区二区中文| 国产一级特黄a大片99| 粉嫩一区二区三区| 欧美成人在线影院| 欧美高清电影在线| 91精品国产免费久久综合| a v视频在线观看| 国产精品久久久久国产精品日日| 国产艳妇疯狂做爰视频| 免费在线欧美视频| 日本a在线免费观看| 日韩1区2区| 国内成+人亚洲| 亚瑟国产精品| 欧美在线视频免费播放| 自由的xxxx在线视频| 亚洲人成免费电影| 精品国产va久久久久久久| 91福利在线观看| 国产中文字幕免费| 日韩久久一区二区| 九九九视频在线观看| 成人精品国产免费网站| 99日在线视频| 日本人妖一区二区| 国产精品秘入口18禁麻豆免会员| 欧美黄色一区二区| 伊人久久大香线蕉精品| 要久久爱电视剧全集完整观看| 亚洲aⅴ男人的天堂在线观看| 桃花岛成人影院| 韩国欧美亚洲国产| 女同一区二区免费aⅴ| 色妞久久福利网| 欧美视频免费一区二区三区| 亚洲成人999| 精品区在线观看| 欧美丰满少妇xxxxx高潮对白| 国产女主播喷水视频在线观看 | 日韩精品视频三区| 人妻中文字幕一区| 日韩午夜中文字幕| av男人天堂av| 欧美日本一区二区在线观看| 免费黄色片视频| 91高清视频在线| 无码人妻丰满熟妇精品区| 激情成人在线视频| 日韩欧美三级视频| 亚洲成人av一区二区三区| 欧美精品一级片| 亚洲黄色性网站| 一区视频免费观看| 一区二区三区国产豹纹内裤在线| 亚洲精品一区二区三区在线播放| 国产日韩欧美精品在线| 久久久久久亚洲中文字幕无码| 99re热这里只有精品视频| 免费看毛片的网站| 99国产精品国产精品毛片| 亚洲av成人片无码| 91老司机福利 在线| 在线观看福利片| 久久精品亚洲精品国产欧美| 亚洲最大成人综合网| 国产亚洲精品aa| 1024在线看片| 日韩一区有码在线| 九九热这里有精品视频| 性感美女极品91精品| 在线免费黄色av| 色婷婷精品久久二区二区蜜臂av | 欧美日韩成人在线| 国产又大又粗又长| 日韩欧美一级片| 欧美特级特黄aaaaaa在线看| 亚洲精品久久久久久久久久久久久 | 亚洲欧美激情国产综合久久久| 亚洲第一区在线| 欧美日韩在线中文字幕| 中文日韩在线观看| 黄在线免费看| 久久久久久久国产精品视频| 国产理论在线| 国产精品成人国产乱一区| 国外成人福利视频| 99精品欧美一区二区三区| 日韩黄色网络| 亚洲精品一区二区三区四区五区| 欧美在线网址| 欧美日韩在线视频一区二区三区| 免费人成精品欧美精品 | 国产精品传媒麻豆hd| 国产在线久久久| 亚洲一区二区三区在线免费| 欧美成人蜜桃| 希岛爱理一区二区三区| 99在线精品免费视频| 日韩国产精品久久| 天天干天天操天天做| www.日韩精品| 秋霞网一区二区三区| 亚洲最大成人网4388xx| 波多野结衣在线观看视频| 日韩欧美一区二区三区在线| 全部免费毛片在线播放网站| 北条麻妃99精品青青久久| 男人天堂亚洲天堂| 国产精品久久久久影院日本| 欧美特黄不卡| 欧洲高清一区二区| 亚洲一区二区三区无吗| 免费成人午夜视频| 久久爱www久久做| 特级西西人体wwwww| 亚洲人精品午夜| 成人av网站在线播放| 精品国产1区二区| 欧美性天天影视| 欧美综合在线观看| heyzo欧美激情| 91免费视频黄| 秋霞影院一区二区| 三叶草欧洲码在线| 亚洲综合色自拍一区| 国产理论片在线观看| 国产一区二区日韩| 天堂网在线最新版www中文网| 成人9ⅰ免费影视网站| 91亚洲成人| 黄色av免费在线播放| 91麻豆swag| 一级片免费网址| 欧美大片在线观看一区二区| 秋霞成人影院| 国产精品久久久久77777| 视频小说一区二区| 免费不卡av在线| 国产成人自拍在线| 人妻久久一区二区| 7777精品伊人久久久大香线蕉经典版下载 | 午夜视频在线观看免费视频| 国产精品成人久久久久| 亚洲香蕉视频| 一本大道熟女人妻中文字幕在线 | 国产91免费在线观看| 欧美成人免费va影院高清| 亚洲精品66| 黄色一级片网址| 久久99国产精品久久99| 天堂资源在线视频| 欧美日韩色综合| 91吃瓜网在线观看| 国产精品啪视频| 日韩综合在线| 亚洲精品午夜在线观看| 国产精品久久久久一区二区三区共| 国产在线观看第一页| 中文字幕日韩综合av| h1515四虎成人| 亚洲欧洲三级| 久久99国产精品尤物| 韩国一级黄色录像| 日韩欧美色综合| 欧美bbbxxxxx| 国产欧美日韩一区| 亚洲毛片视频| 日韩av在线看免费观看| 色哟哟精品一区| 成人综合影院| 国产欧美精品在线播放| 久久久久久久久丰满| 中文字幕人妻无码系列第三区| 亚洲精品写真福利| 成人乱码一区二区三区| 2019日本中文字幕| 国产videos久久| 国产aⅴ爽av久久久久| 一区二区三区日本| 亚洲区小说区图片区| 国产精品h在线观看| 亚洲91久久| 北京富婆泄欲对白| 91黄色激情网站| 免费在线午夜视频| 国模精品一区二区三区| 热久久免费视频| 免费人成视频在线| 精品亚洲一区二区| 日本在线一区二区| 少妇大叫太大太粗太爽了a片小说| www.日韩在线| 在线免费看91| 久久人人爽人人爽人人片av高清| 在线看成人短视频| 欧洲在线免费视频| 婷婷成人综合网| 麻豆视频在线| 国产一区二区精品在线| 久久精品国产99国产| 国产在线拍揄自揄拍| 中文字幕欧美精品日韩中文字幕| 日本高清精品|