在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

電子發(fā)燒友App

硬聲App

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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(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
開(kāi)發(fā)語(yǔ)言 TypeScript
操作系統(tǒng) 跨平臺(tái)
軟件類型 開(kāi)源軟件

軟件簡(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 擁有類似于建站工具的能力。

pYYBAGJ7KSGAIdPBAAW2YY5ML34380.png

安裝

通過(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)地址

TextBus 官網(wǎng)

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

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

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

對(duì)于以上所列舉的只是部分問(wèn)題,有問(wèn)題雖然不好,但也不完全是壞事,這時(shí)就需要 TextBus 來(lái)解決這些問(wèn)題。針對(duì)上面的問(wèn)題,TextBus 解決如下:

  1. TextBus 輸出非常干凈,沒(méi)有冗余的標(biāo)簽及樣式。
  2. 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)不了的。
  3. TextBus 不依賴特定的庫(kù),開(kāi)箱即用。
  4. TextBus 擴(kuò)展真的很簡(jiǎn)單,如果你使用 Typescript 開(kāi)發(fā)的話,IDE 會(huì)給你非常好的代碼提示,你只需要實(shí)現(xiàn)對(duì)應(yīng)的接口,其它的就交給 TextBus 幫你處理。
  5. 實(shí)時(shí)代碼高亮,在 TextBus 里真的不是問(wèn)題。
  6. 由于 TextBus 的架構(gòu)設(shè)計(jì)天然的支持過(guò)濾臟內(nèi)容,所以,當(dāng)粘貼進(jìn) TextBus 不認(rèn)識(shí)的數(shù)據(jù)時(shí),會(huì)自動(dòng)忽略掉,而不會(huì)遺留在最終的結(jié)果里。
  7. 粘貼進(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 效果了

?

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

評(píng)論

查看更多

下載排行

本周

  1. 1山景DSP芯片AP8248A2數(shù)據(jù)手冊(cè)
  2. 1.06 MB  |  532次下載  |  免費(fèi)
  3. 2RK3399完整板原理圖(支持平板,盒子VR)
  4. 3.28 MB  |  339次下載  |  免費(fèi)
  5. 3TC358743XBG評(píng)估板參考手冊(cè)
  6. 1.36 MB  |  330次下載  |  免費(fèi)
  7. 4DFM軟件使用教程
  8. 0.84 MB  |  295次下載  |  免費(fèi)
  9. 5元宇宙深度解析—未來(lái)的未來(lái)-風(fēng)口還是泡沫
  10. 6.40 MB  |  227次下載  |  免費(fèi)
  11. 6迪文DGUS開(kāi)發(fā)指南
  12. 31.67 MB  |  194次下載  |  免費(fèi)
  13. 7元宇宙底層硬件系列報(bào)告
  14. 13.42 MB  |  182次下載  |  免費(fèi)
  15. 8FP5207XR-G1中文應(yīng)用手冊(cè)
  16. 1.09 MB  |  178次下載  |  免費(fèi)

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費(fèi)
  3. 2555集成電路應(yīng)用800例(新編版)
  4. 0.00 MB  |  33566次下載  |  免費(fèi)
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費(fèi)
  7. 4開(kāi)關(guān)電源設(shè)計(jì)實(shí)例指南
  8. 未知  |  21549次下載  |  免費(fèi)
  9. 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書)
  10. 0.00 MB  |  15349次下載  |  免費(fèi)
  11. 6數(shù)字電路基礎(chǔ)pdf(下載)
  12. 未知  |  13750次下載  |  免費(fèi)
  13. 7電子制作實(shí)例集錦 下載
  14. 未知  |  8113次下載  |  免費(fèi)
  15. 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德?tīng)栔?/a>
  16. 0.00 MB  |  6656次下載  |  免費(fèi)

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費(fèi)
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537798次下載  |  免費(fèi)
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420027次下載  |  免費(fèi)
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費(fèi)
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費(fèi)
  11. 6電路仿真軟件multisim 10.0免費(fèi)下載
  12. 340992  |  191187次下載  |  免費(fèi)
  13. 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
  14. 158M  |  183279次下載  |  免費(fèi)
  15. 8proe5.0野火版下載(中文版免費(fèi)下載)
  16. 未知  |  138040次下載  |  免費(fèi)
主站蜘蛛池模板: 性视频久久| 免费黄色a视频| 国产一级特黄全黄毛片| 手机看片1024手机在线观看| 48pao强力打造免费基地| 四虎影院永久在线观看| www.操你啦| 欧美另类69| 四虎影院在线网址| 伊人狼人综合| 亚洲区中文字幕| 欧美色欧美亚洲高清在线观看| 午夜韩国理论片在线播放| 一区二区福利| 免费一级毛片私人影院a行| 色狠狠色综合吹潮| 99久久免费中文字幕精品| 久久e| 国产成人午夜片在线观看| 亚洲啊v| 怡红院免费va男人的天堂| 亚洲日本一区二区| 毛片网页| 国产高清免费在线观看| 特黄一级毛片| 天天干天天碰| 一级aaa毛片| 97蜜桃| 美女张开腿让男生桶出水| 久久h| 丁香六月激情网| 欧美大片一区二区三区| 久久久久久久免费| 天堂资源在线www中文| 亚洲第一视频在线播放| 国产在播放一区| www色网站| 男女免费视频| 国产福利资源在线| 欧美不在线| 精品国产一二三区|