99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>TextBus Typescript編寫的富文本編輯器

TextBus Typescript編寫的富文本編輯器

2022-05-23 | zip | 0.86 MB | 次下載 | 2積分

資料介紹

授權(quán)協(xié)議 GPL
開發(fā)語言 TypeScript
軟件類型 開源軟件

軟件簡介

TextBus 是一個通過自建數(shù)據(jù)模型、內(nèi)置 Diff 算法、以數(shù)據(jù)為核心驅(qū)動的富文本編輯器。

同時,TextBus 擁有非常好的可擴(kuò)展性和定制能力,你可以基于 TextBus 的數(shù)據(jù)模型擴(kuò)展自己的組件(Component)、格式(Formatter)及工具。當(dāng)然,內(nèi)置的組件、格式、工具、插件等,你也可以隨意添加和刪除。甚至,你也可以把 TextBus 當(dāng)成一個源碼生成器,通過定制組件的?render?方法,輸出 Vue、React 或 Angular 的模板源代碼。因此 TextBus 擁有類似于建站工具的能力。

pYYBAGJ7KSGAIdPBAAW2YY5ML34380.png

安裝

通過 npm 安裝 TextBus:

npm install @textbus/textbus

在 html 中準(zhǔn)備一個空的元素


   id="editor">

通過 css 選擇器,或直接傳入一個 DOM 元素初始化 TextBus。

import { createEditor } from '@textbus/textbus';
import { Observable } from 'rxjs';

const editor = createEditor('#editor', {
  uploader(type: string): string | Promise<string> | Observable<string> {
    // switch (type) {
    //   case 'video':
    //     console.log('上傳視頻');
    //     break;
    //   case 'image':
    //     console.log('上傳視頻');
    //     break;
    //   case 'audio':
    //     console.log('上傳音頻');
    //     break;
    // }
    return Promise.resolve().then(() => {
      return '/test'
    })
  },
  content: `

歡迎你使用 TextBus 富文本編輯器...

`
}); editor.onChange.subscribe(() => { console.log(editor.getContents()); });

官網(wǎng)地址

TextBus 官網(wǎng)

為什么要開發(fā) TextBus?

眾所周知,富文本編輯器一直是前端開發(fā)領(lǐng)域的一個天坑。但同時市面上的富文本編輯器卻又?jǐn)?shù)不勝數(shù),那為什么我還要另起爐灶呢?

  1. 目前大多數(shù)富文本內(nèi)容都太臟了,比如,加粗一段文字,可能是一個 strong 標(biāo)簽,也有可能是多個,如果這段文字同時還有其它格式,那么就更熱鬧了,基本處于一個不可控的狀態(tài)。能把顯示狀態(tài)和編輯處理成正常的,就算很不錯的編輯器,基本不會管內(nèi)容臟不臟的問題。
  2. 目前比較新的編輯器,基本都有自己的一套抽象數(shù)據(jù)結(jié)構(gòu)來描述富文本,這同時又引起了另一個問題,即這一數(shù)據(jù)結(jié)構(gòu)對有的富文本內(nèi)容描述不了,導(dǎo)致要擴(kuò)展特定的格式不能實現(xiàn)。
  3. 部分富文本編輯器依賴特定的框架或庫,造成使用上的限制。
  4. 擴(kuò)展困難,不能方便的擴(kuò)展格式、組件和模板,也不方便定制特定的編輯行為。
  5. 實時的代碼高亮,這個對程序員寫文檔來說,是一個比較重要的功能。
  6. 對于粘貼進(jìn)來的內(nèi)容,要么粗爆的只是提取文本內(nèi)容,導(dǎo)致格式丟失。要么就直接扔進(jìn)頁面,產(chǎn)生非常多的臟數(shù)據(jù)(如粘貼 word 的內(nèi)容),雖然有的編輯器做了過濾,但基本不能做到完全剔除臟數(shù)據(jù)。
  7. 粘貼進(jìn)來的資源不能觸發(fā)上傳行為。

對于以上所列舉的只是部分問題,有問題雖然不好,但也不完全是壞事,這時就需要 TextBus 來解決這些問題。針對上面的問題,TextBus 解決如下:

  1. TextBus 輸出非常干凈,沒有冗余的標(biāo)簽及樣式。
  2. TextBus 沒有定義一個標(biāo)準(zhǔn)的數(shù)據(jù)結(jié)構(gòu),只抽象出了 Formatter(格式) 和 Component(組件)兩個維度的數(shù)據(jù)來格式化富文本的 Content(內(nèi)容)?,F(xiàn)在大家日?;径际墙M件化開發(fā),TextBus 也有自己的組件,你可以像寫 Vue/React/Angular 組件一樣,來寫 TextBus 的組件,只要你愿意,沒有什么效果是實現(xiàn)不了的。
  3. TextBus 不依賴特定的庫,開箱即用。
  4. TextBus 擴(kuò)展真的很簡單,如果你使用 Typescript 開發(fā)的話,IDE 會給你非常好的代碼提示,你只需要實現(xiàn)對應(yīng)的接口,其它的就交給 TextBus 幫你處理。
  5. 實時代碼高亮,在 TextBus 里真的不是問題。
  6. 由于 TextBus 的架構(gòu)設(shè)計天然的支持過濾臟內(nèi)容,所以,當(dāng)粘貼進(jìn) TextBus 不認(rèn)識的數(shù)據(jù)時,會自動忽略掉,而不會遺留在最終的結(jié)果里。
  7. 粘貼進(jìn)來的資源上傳,會自動分析,并觸發(fā)上傳。

當(dāng)然,除了上述列舉的問題,其實大家可能還有更多的需求亟待解決,這里就不一一闡述了,歡迎大家試用,并給出評價。更歡迎提出問題,要是能一起來完善 TextBus,那就更好了!

開發(fā)環(huán)境

對于一部分需要更詳細(xì)了解 TextBus 原理,需要本地調(diào)試的開發(fā)者來說,可以通過以下方式在本地運(yùn)行 TextBus。

TextBus 采用 lerna 作為多模塊管理工具。如果你沒有安裝,請先安裝 lerna。

npm install -g lerna

在項目根目錄,通過 lerna 安裝本地依賴

lerna bootstrap --hoist

啟動項目

npm start

至此,你就可以在瀏覽器看到開發(fā)版本的 TextBus 效果了

?

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1DD3118電路圖紙資料
  2. 0.08 MB   |  1次下載  |  免費(fèi)
  3. 2AD庫封裝庫安裝教程
  4. 0.49 MB   |  1次下載  |  免費(fèi)
  5. 3PC6206 300mA低功耗低壓差線性穩(wěn)壓器中文資料
  6. 1.12 MB   |  1次下載  |  免費(fèi)
  7. 4網(wǎng)絡(luò)安全從業(yè)者入門指南
  8. 2.91 MB   |  1次下載  |  免費(fèi)
  9. 5DS-CS3A P00-CN-V3
  10. 618.05 KB  |  1次下載  |  免費(fèi)
  11. 6海川SM5701規(guī)格書
  12. 1.48 MB  |  次下載  |  免費(fèi)
  13. 7H20PR5電磁爐IGBT功率管規(guī)格書
  14. 1.68 MB   |  次下載  |  1 積分
  15. 8IP防護(hù)等級說明
  16. 0.08 MB   |  次下載  |  免費(fèi)

本月

  1. 1貼片三極管上的印字與真實名稱的對照表詳細(xì)說明
  2. 0.50 MB   |  103次下載  |  1 積分
  3. 2涂鴉各WiFi模塊原理圖加PCB封裝
  4. 11.75 MB   |  89次下載  |  1 積分
  5. 3錦銳科技CA51F2 SDK開發(fā)包
  6. 24.06 MB   |  43次下載  |  1 積分
  7. 4錦銳CA51F005 SDK開發(fā)包
  8. 19.47 MB   |  19次下載  |  1 積分
  9. 5PCB的EMC設(shè)計指南
  10. 2.47 MB   |  16次下載  |  1 積分
  11. 6HC05藍(lán)牙原理圖加PCB
  12. 15.76 MB   |  13次下載  |  1 積分
  13. 7802.11_Wireless_Networks
  14. 4.17 MB   |  12次下載  |  免費(fèi)
  15. 8蘋果iphone 11電路原理圖
  16. 4.98 MB   |  6次下載  |  2 積分

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935127次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
  4. 1.48MB  |  420064次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233089次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費(fèi)下載
  8. 340992  |  191390次下載  |  10 積分
  9. 5十天學(xué)會AVR單片機(jī)與C語言視頻教程 下載
  10. 158M  |  183342次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81588次下載  |  10 積分
  13. 7Keil工具M(jìn)DK-Arm免費(fèi)下載
  14. 0.02 MB  |  73815次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65989次下載  |  10 積分