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 都能提供高效、稳定的解决方案。

相关推荐
lkbhua莱克瓦2410 分钟前
Java基础——集合进阶用到的数据结构知识点1
java·数据结构·笔记·github
lkbhua莱克瓦244 小时前
Java基础——常用算法3
java·数据结构·笔记·算法·github·排序算法·学习方法
吃饺子不吃馅6 小时前
前端画布类型编辑器项目,历史记录技术方案调研
前端·架构·github
省四收割者6 小时前
GitHub Action工作流语法
笔记·github
QT 小鲜肉7 小时前
【Git、GitHub、Gitee】按功能分类汇总Git常用命令详解(超详细)
c语言·网络·c++·git·qt·gitee·github
散峰而望10 小时前
基本魔法语言函数(一)(C语言)
c语言·开发语言·编辑器·github
oil欧哟10 小时前
GitHub星标3万,OpenAI 官方支持——深度解读 AI Agent 连接协议的行业标准 MCP
人工智能·github
粟悟饭&龟波功10 小时前
【GitHub热门项目】(2025-11-07)
github
一名爱学习的ikun11 小时前
如何将本地文件上传至Github?【详细解释】
github