資料介紹
軟件簡(jiǎn)介
TextBus 是一個(gè)通過(guò)自建數(shù)據(jù)模型、內(nèi)置 Diff 算法、以數(shù)據(jù)為核心驅(qū)動(dòng)的富文本編輯器。
同時(shí),TextBus 擁有非常好的可擴(kuò)展性和定制能力,你可以基于 TextBus 的數(shù)據(jù)模型擴(kuò)展自己的組件(Component)、格式(Formatter)及工具。當(dāng)然,內(nèi)置的組件、格式、工具、插件等,你也可以隨意添加和刪除。甚至,你也可以把 TextBus 當(dāng)成一個(gè)源碼生成器,通過(guò)定制組件的?render
?方法,輸出 Vue、React 或 Angular 的模板源代碼。因此 TextBus 擁有類似于建站工具的能力。
安裝
通過(guò) npm 安裝 TextBus:
npm install @textbus/textbus
在 html 中準(zhǔn)備一個(gè)空的元素
id="editor">
通過(guò) css 選擇器,或直接傳入一個(gè) 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)地址
為什么要開(kāi)發(fā) TextBus?
眾所周知,富文本編輯器一直是前端開(kāi)發(fā)領(lǐng)域的一個(gè)天坑。但同時(shí)市面上的富文本編輯器卻又?jǐn)?shù)不勝數(shù),那為什么我還要另起爐灶呢?
- 目前大多數(shù)富文本內(nèi)容都太臟了,比如,加粗一段文字,可能是一個(gè) strong 標(biāo)簽,也有可能是多個(gè),如果這段文字同時(shí)還有其它格式,那么就更熱鬧了,基本處于一個(gè)不可控的狀態(tài)。能把顯示狀態(tài)和編輯處理成正常的,就算很不錯(cuò)的編輯器,基本不會(huì)管內(nèi)容臟不臟的問(wèn)題。
- 目前比較新的編輯器,基本都有自己的一套抽象數(shù)據(jù)結(jié)構(gòu)來(lái)描述富文本,這同時(shí)又引起了另一個(gè)問(wèn)題,即這一數(shù)據(jù)結(jié)構(gòu)對(duì)有的富文本內(nèi)容描述不了,導(dǎo)致要擴(kuò)展特定的格式不能實(shí)現(xiàn)。
- 部分富文本編輯器依賴特定的框架或庫(kù),造成使用上的限制。
- 擴(kuò)展困難,不能方便的擴(kuò)展格式、組件和模板,也不方便定制特定的編輯行為。
- 實(shí)時(shí)的代碼高亮,這個(gè)對(duì)程序員寫文檔來(lái)說(shuō),是一個(gè)比較重要的功能。
- 對(duì)于粘貼進(jìn)來(lái)的內(nèi)容,要么粗爆的只是提取文本內(nèi)容,導(dǎo)致格式丟失。要么就直接扔進(jìn)頁(yè)面,產(chǎn)生非常多的臟數(shù)據(jù)(如粘貼 word 的內(nèi)容),雖然有的編輯器做了過(guò)濾,但基本不能做到完全剔除臟數(shù)據(jù)。
- 粘貼進(jìn)來(lái)的資源不能觸發(fā)上傳行為。
對(duì)于以上所列舉的只是部分問(wèn)題,有問(wèn)題雖然不好,但也不完全是壞事,這時(shí)就需要 TextBus 來(lái)解決這些問(wèn)題。針對(duì)上面的問(wèn)題,TextBus 解決如下:
- TextBus 輸出非常干凈,沒(méi)有冗余的標(biāo)簽及樣式。
- TextBus 沒(méi)有定義一個(gè)標(biāo)準(zhǔn)的數(shù)據(jù)結(jié)構(gòu),只抽象出了 Formatter(格式) 和 Component(組件)兩個(gè)維度的數(shù)據(jù)來(lái)格式化富文本的 Content(內(nèi)容)。現(xiàn)在大家日常基本都是組件化開(kāi)發(fā),TextBus 也有自己的組件,你可以像寫 Vue/React/Angular 組件一樣,來(lái)寫 TextBus 的組件,只要你愿意,沒(méi)有什么效果是實(shí)現(xiàn)不了的。
- TextBus 不依賴特定的庫(kù),開(kāi)箱即用。
- TextBus 擴(kuò)展真的很簡(jiǎn)單,如果你使用 Typescript 開(kāi)發(fā)的話,IDE 會(huì)給你非常好的代碼提示,你只需要實(shí)現(xiàn)對(duì)應(yīng)的接口,其它的就交給 TextBus 幫你處理。
- 實(shí)時(shí)代碼高亮,在 TextBus 里真的不是問(wèn)題。
- 由于 TextBus 的架構(gòu)設(shè)計(jì)天然的支持過(guò)濾臟內(nèi)容,所以,當(dāng)粘貼進(jìn) TextBus 不認(rèn)識(shí)的數(shù)據(jù)時(shí),會(huì)自動(dòng)忽略掉,而不會(huì)遺留在最終的結(jié)果里。
- 粘貼進(jìn)來(lái)的資源上傳,會(huì)自動(dòng)分析,并觸發(fā)上傳。
當(dāng)然,除了上述列舉的問(wèn)題,其實(shí)大家可能還有更多的需求亟待解決,這里就不一一闡述了,歡迎大家試用,并給出評(píng)價(jià)。更歡迎提出問(wèn)題,要是能一起來(lái)完善 TextBus,那就更好了!
開(kāi)發(fā)環(huán)境
對(duì)于一部分需要更詳細(xì)了解 TextBus 原理,需要本地調(diào)試的開(kāi)發(fā)者來(lái)說(shuō),可以通過(guò)以下方式在本地運(yùn)行 TextBus。
TextBus 采用 lerna 作為多模塊管理工具。如果你沒(méi)有安裝,請(qǐng)先安裝 lerna。
npm install -g lerna
在項(xiàng)目根目錄,通過(guò) lerna 安裝本地依賴
lerna bootstrap --hoist
啟動(dòng)項(xiàng)目
npm start
至此,你就可以在瀏覽器看到開(kāi)發(fā)版本的 TextBus 效果了
- 超好用的Win/Mac文本編輯器npp.7.9.5.Installer 5次下載
- Python文本編輯器實(shí)用工具免費(fèi)下載 0次下載
- 如何進(jìn)行HTML在線文本編輯器在Java web開(kāi)發(fā)中的使用分析 10次下載
- 如何從Linux中探討Ⅵ編輯器的教學(xué)問(wèn)題 9次下載
- linux系統(tǒng)教程之Vi編輯器的使用教程免費(fèi)下載 52次下載
- UltraEdit文本編輯器免費(fèi)下載 0次下載
- CentOS下vi編輯器用法大全 2次下載
- JAVA教程之簡(jiǎn)單的文本編輯器 11次下載
- UltraEdit_文本編輯器 13次下載
- EditPlus(文本編輯器)下載入口 4次下載
- 程序員必備的文本編輯器_GVim for windows 4次下載
- 文本編輯器的實(shí)現(xiàn) 0次下載
- linux_vi命令詳解-屏幕文本編輯器
- linux文本編輯器工具下載
- java文本編輯器下載(源代碼)
- UltraEdit文本編輯功能介紹 3989次閱讀
- VSCode編輯器的安裝及使用教程是什么 1374次閱讀
- 如何使用Gnu nano文本編輯器 5631次閱讀
- Vim編輯器的使用學(xué)習(xí)和使用技巧 2068次閱讀
- 基于終端的Linux 編輯器 2920次閱讀
- 在Linux上使用JOE文本編輯器的方法 3307次閱讀
- 使用Atom文本編輯器的五個(gè)優(yōu)勢(shì) 4011次閱讀
- Xedit文本編輯器的使用指南 2670次閱讀
- PADS的元件編輯器的使用方法 8796次閱讀
- 干貨 | Linux 流編輯器 SED 詳解 2947次閱讀
- 我們有各種現(xiàn)代文本編輯器,還有必要學(xué)習(xí)Vim嗎? 3658次閱讀
- 幾款小巧好用的C語(yǔ)言編輯器 4w次閱讀
- VI 編輯器的命令、模式和選項(xiàng)介紹 6124次閱讀
- 分享3個(gè)可以替代Emacs和Vim的編輯器:Geany、Atom、Xed 1.2w次閱讀
- 編譯器跟編輯器有什么區(qū)別 2.9w次閱讀
下載排行
本周
- 1山景DSP芯片AP8248A2數(shù)據(jù)手冊(cè)
- 1.06 MB | 532次下載 | 免費(fèi)
- 2RK3399完整板原理圖(支持平板,盒子VR)
- 3.28 MB | 339次下載 | 免費(fèi)
- 3TC358743XBG評(píng)估板參考手冊(cè)
- 1.36 MB | 330次下載 | 免費(fèi)
- 4DFM軟件使用教程
- 0.84 MB | 295次下載 | 免費(fèi)
- 5元宇宙深度解析—未來(lái)的未來(lái)-風(fēng)口還是泡沫
- 6.40 MB | 227次下載 | 免費(fèi)
- 6迪文DGUS開(kāi)發(fā)指南
- 31.67 MB | 194次下載 | 免費(fèi)
- 7元宇宙底層硬件系列報(bào)告
- 13.42 MB | 182次下載 | 免費(fèi)
- 8FP5207XR-G1中文應(yīng)用手冊(cè)
- 1.09 MB | 178次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33566次下載 | 免費(fèi)
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費(fèi)
- 4開(kāi)關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21549次下載 | 免費(fèi)
- 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費(fèi)
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費(fèi)
- 7電子制作實(shí)例集錦 下載
- 未知 | 8113次下載 | 免費(fèi)
- 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德?tīng)栔?/a>
- 0.00 MB | 6656次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537798次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420027次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191187次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183279次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138040次下載 | 免費(fèi)
評(píng)論
查看更多