Github超19k+ strar的实时协同编辑的开源框架yjs

Yjs 是一个用于实现实时协同编辑的开源框架,具有以下关键特性和应用价值:

核心特性

  1. 基于 CRDT 算法

    Yjs 采用无冲突复制数据类型(CRDT),确保多用户同时编辑同一文档时无需复杂锁机制或中央协调,最终实现数据一致性。其底层通过双向链表结构记录操作,保证操作的顺序无关性和幂等性。

  2. 多种数据类型支持

    提供 YArray、YMap、YText 等共享数据类型,支持文本、数组、键值对等常见数据结构的协同操作,满足多样化应用需求。

  3. 灵活的网络同步

    支持 WebSocket、WebRTC 等多种传输协议,通过 y-websocket、y-webrtc 等插件实现实时通信,确保多客户端数据同步。

  4. 用户状态追踪

    内置 Awareness 协议,可跟踪用户在线状态、光标位置等,增强协同编辑的交互体验。

  5. 权限控制与认证

    通过 Auth 模块支持用户认证和权限管理,确保文档访问的安全性。

应用场景

  1. 实时文档协作

    类似 Google Docs 的多用户实时编辑功能,适用于在线文档、表格等场景。

  2. 协同编程

    支持开发者实时协作编写代码,提升团队效率。

  3. 项目管理工具

    多人协同规划任务、分配进度,适用于团队协作平台。

  4. 在线教育

    教师与学生共享文档进行在线教学或作业批改。

  5. 图形编辑器协同

    支持图形、思维导图等复杂数据结构的协同编辑,通过数据结构转换实现高效同步。

技术优势

  1. 去中心化架构

    减少对中心服务器的依赖,支持点对点通信,提升系统容错性。

  2. 离线编辑支持

    用户可在离线状态下编辑,恢复网络后自动同步数据。

  3. 版本控制与回滚

    支持版本快照和撤销/重做操作,便于历史记录管理。

  4. 高性能与扩展性

    优化内存使用和传输效率,支持大规模用户协同。

生态与集成

  • 编辑器集成:提供 y-prosemirror、y-quill、y-codemirror 、y-monaco等插件,轻松集成主流富文本编辑器。
  • 前端框架支持:通过 syncedstore 等库与 React、Vue 等框架无缝结合。
  • 持久化存储:支持将数据持久化到 Redis、IndexedDB 等存储系统。

使用示例

以下是一个简单的 Yjs 协同编辑器实现流程:

初始化 Yjs 文档:

复制代码
import * as Y from 'yjs';
const doc = new Y.Doc();
设置 WebSocket 连接:
复制代码
import { WebsocketProvider } from 'y-websocket';
const provider = new WebsocketProvider('ws://localhost:1234', 'roomName', doc);
监听文档变化:
复制代码
doc.on('update', (update) => {
  console.log('文档已更新:', update);
});
共享数据操作:
复制代码
const sharedArray = doc.getArray('sharedArray');
sharedArray.push(['Hello', 'Yjs']); // 添加数据

vue简单用法

复制代码
  </main>
</template>

<script>
import { store } from "./store";
import { ref } from "vue";
import * as Vue from "vue";
import { enableVueBindings } from "@syncedstore/core";

// make SyncedStore use Vuejs internally
enableVueBindings(Vue);

export default {
  name: "App",
  data() {
    return {
      store, // Put the store on the data() of the component
      newTodo: ""
    };
  },
  methods: {
    addTodo() {
      const value = this.newTodo && this.newTodo.trim();
      if (!value) {
        return;
      }
      this.store.todos.push({
        title: value,
        completed: false,
      });
      this.newTodo = "";
    },
    removeTodo(todo) {
      this.store.todos.splice(this.store.todos.indexOf(todo), 1);
    }
  }
};
</script>

<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}

ul {
  text-align:left;
}

li button {
  margin-left:1em;
}
</style>

import { syncedStore, getYjsDoc } from "@syncedstore/core";
import { WebrtcProvider } from "y-webrtc";

// (optional, define types for TypeScript)
type Todo = { completed: boolean, title: string };

// Create your SyncedStore store
export const store = syncedStore({ todos: [] as Todo[], fragment: "xml" });

// Create a document that syncs automatically using Y-WebRTC
const doc = getYjsDoc(store);
export const webrtcProvider = new WebrtcProvider("syncedstore-todos", doc);

export const disconnect = () => webrtcProvider.disconnect();
export const connect = () => webrtcProvider.connect();

总结

Yjs 是一个功能强大、灵活易用的实时协同编辑框架,适用于需要多用户协作的各类应用场景。其基于 CRDT 的算法设计、丰富的数据类型支持、灵活的网络同步方式以及完善的生态集成,使其成为开发协同应用的理想选择。无论是文档协作、编程开发还是项目管理,Yjs 都能提供高效、稳定的解决方案。

相关推荐
独自归家的兔10 小时前
AI界的 GitHub?Hugging Face 全面解析
人工智能·github
逛逛GitHub13 小时前
GitHub 上刚开源的国产 3D 高斯浏览器,杭州六小龙给力啊。
github
code_li14 小时前
免费服务器指南:GitHub Pages搭建静态网站全攻略
github·部署·免费服务器
阿里嘎多学长15 小时前
2026-05-28 GitHub 热点项目精选
开发语言·程序员·github·代码托管
小小程序员mono17 小时前
模型进入「日更时代」:GPT-5.6 泄露、Claude 4.8 逼近、Gemini 3.5 上线、国产杀疯了摘要
人工智能·重构·开源·github
Larcher17 小时前
「Codex + DeepSeek 用户请进:你的对话记录是不是也卡到想砸键盘?」
人工智能·github·编程语言
程序员柒叔18 小时前
Dify 一周动态-2026-W22
人工智能·大模型·github·agent·知识库·dify
Cloud_Shy61819 小时前
Linux 系统定时任务Cron(d)服务应用实践(三:定时任务调试技巧及故障分析解决)
linux·网络·centos·云计算·github·运维开发
DogDaoDao19 小时前
【GitHub】RealtimeSTT 深度解析:打造低延迟、生产级语音识别应用的全栈利器
人工智能·语言模型·大模型·github·语音识别·stt·realtimestt
Hommy882 天前
【剪映小助手】视频处理接口
开源·github·音视频·视频剪辑自动化·剪映api