成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

推薦!PowerNice Web版+桌面端軟件,讓文檔編輯更簡單

開源 開發工具
「powerNice」 提供兩種方式來編寫文章/文檔, 即程序員最喜歡的 markdown, 也可以使用非技術人員最容易上手的富文本編輯器.

前言?

大家好, 我是徐小夕, 之前和大家分享了一個在線文檔編輯器PowerNice, 它可以輕松幫我們編寫文檔并一鍵導出多種格式比如html,pdf, md, png圖片等, 如下:

圖片

最近為了讓編輯器滿足更多場景需求, 我開發了桌面端軟件版本——powernice-electron, 支持mac 和 window。

圖片

接下來我來對powernice 技術實現和功能做一個介紹。

背景?

作為一名技術工作者, 我們經常會遇到編寫技術文檔, 技術分享等需求, 網上也有很多現成的文檔管理工具, 出于好奇心, 我拉著朋友一起實現了一個, 用來自給自足. 接下來就來介紹一下輕量級且靈活方便的文檔編輯工具—— 「powerNice」。

「powerNice」 提供兩種方式來編寫文章/文檔, 即程序員最喜歡的 ??markdown??, 也可以使用非技術人員最容易上手的富文本編輯器。

demo演示?

圖片

技術選型?

實現 「powerNice」 在線文檔編輯器我們采用如下核心技術棧:

  • React
  • Ant Design
  • Dva
  • For-editor
  • Braft-editor
  • Nodejs
  • 瀏覽器指紋識別技術

功能盤點?

1、多模式編輯

多模式編輯主要是指我們可以用富文本和md編輯器來編輯我們的文章, 我們采用最熟悉的 React 來實現, 效果如下:

圖片圖片

2、多主題

目前支持2套主題, 淺色和深色, 主要從用戶體驗的角度方便用戶夜間寫作. 效果如下:

(1)深色。

圖片

(2)淺色。

圖片

3、支持一鍵導入導出

為了提高我們的寫作效率以及對文章的多路復用, 我們提供了一鍵導入導出文件等功能, 具體如下:

  • 導出Markdown。
  • 導出PDF。
  • 基于文章導出海報圖。
  • 導入Markdown 文件。
  • 下載文章html 內容。

使用截圖如下:

圖片


下載的html內容預覽如下:圖片還原度還是非常高的。

4、多模式預覽

多模式預覽主要是右側的預覽區, 我們支持手機端預覽和pc端預覽, 如下圖:

圖片

圖片

5、字數行數統計

字數行數統計主要是幫助作者做內容統計, 這塊實現不是很難, 我們看看預覽效果:

圖片

6、文章管理

文章管理主要是管理用戶編寫的內容, 這里因為我們做的是線上工具, 用戶識別主要采用瀏覽器指紋識別技術來區分用戶, 用戶可以輕松在編輯器文章列表中切換文章進行編輯, 效果如下:

圖片

核心技術實現?

1、導入導出多類型文件

  • 「導入md/html文件」導入md?文件我們主要利用ant的upload?組件和FileReader API, 具體實現如下:
{
name: 'file',
showUploadList: false,
beforeUpload(file: any): any {
const reader = new FileReader()
reader.onload = function(e: Event) {
const data = (e as any).target.result
if (editor === 'richText') {
// ...
} else {
// ...
}
}
reader.readAsText(file)
},
}
  • 「下載html」下載html?的原理也很簡單, 我們拿到渲染后的html?字符串, 利用html?模版將其包裝成完整的html?, 最后再存儲為File?對象, 利用file-saver?實現下載.  思路如下:

圖片

核心代碼如下:

const doc = document.querySelector('.for-markdown-preview') as HTMLElement
const html = createMDHtml(doc.innerHTML, article)
file = new File([html], `${moment().format('YYYYMMDDHHmmss')}.html`, { type: 'text/html;charset=utf-8' })
// 下載文件
saveAs(file)

2、基于瀏覽器指紋識別技術的用戶識別

瀏覽器指紋這塊知識點涉及的比較多, 筆者這里簡單介紹一下canvas指紋。

「Canvas指紋」是利用系統之間, 字體渲染引擎, 抗鋸齒、次像素渲染等處理方式的差異而實現的一種指紋識別技術. 我們使用canvas將同樣的文字轉成圖片, 即便使用Canvas繪制相同的元素,但由于上述的差別得到的結果也是不同的。?

所以我們可以利用以上技術, 對不同用戶瀏覽器進行識別, 從而區分用戶(雖然存在概率事件), 實現無需登錄就能保存對應內容的目的. 基本實現代碼如下:

createFingerprint = () => {
const canvas = document.getElementById('anchor-uuid') as HTMLCanvasElement
const context = canvas.getContext('2d') as CanvasRenderingContext2D
context.font = '18pt Arial'
context.textBaseline = 'top'
context.fillText('hello, user.', 2, 2)
const fingerprint = canvas.toDataURL('image/jpeg')
// hash
const secret = 'nice'
const hash = crypto.createHmac('sha256', secret)
.update(fingerprint)
.digest('hex')

return hash
}


責任編輯:姜華 來源: 趣談前端
相關推薦

2023-07-04 21:59:46

文檔編輯器PowerNice

2010-03-23 09:54:35

好壓壓縮

2011-08-08 17:51:14

注冊表編輯器注冊表

2009-05-15 17:42:34

ApacheWeb開發Apache Slin

2024-02-19 07:51:52

WebargsPythonWeb

2012-06-20 13:36:42

Surface平板

2011-06-15 09:53:05

思杰虛擬化

2025-01-21 10:45:00

訓練模型架構

2019-04-04 14:05:20

consolejs前端

2019-07-10 10:20:36

前端用戶體驗javascript

2021-12-02 06:58:01

微軟桌面助手

2009-02-24 08:21:22

Windows 7桌面亮麗

2012-09-25 09:28:36

程序員代碼代碼整潔

2020-05-07 10:18:06

JavaScript前端技術

2022-06-05 23:28:50

TypeScripinfer類型

2024-04-26 07:54:07

ZustandReact狀態管理庫

2009-06-18 15:51:52

SSL VPN負載均衡Array

2019-07-08 11:05:05

Windows

2021-07-24 13:16:31

Android 代碼操作系統
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩欧美国产精品综合嫩v 一区中文字幕 | 久草视频网站 | 插插宗合网 | 激情欧美一区二区三区中文字幕 | a级毛片基地 | 中文字幕日韩在线观看 | 毛片的网址 | www97影院| 亚洲欧美日韩电影 | 亚洲国产精品99久久久久久久久 | 久久精品国产99国产精品 | 国产精品高潮呻吟久久久久 | 成人午夜激情 | 亚洲狠狠| 国产精品1区 | 日本一区高清 | 成人av在线播放 | 欧美视频一区二区三区 | 成人毛片视频在线播放 | 一级黄色影片在线观看 | 国产在线精品一区二区 | 久久久精品视频免费 | 日本三级在线 | 欧美精品一区二区三区在线 | 亚洲成网 | 二区av | 中文字幕久久精品 | 一级特黄在线 | 午夜av成人| 日韩一区二区三区视频在线观看 | 欧美高清dvd | 在线免费观看成人 | 精品成人免费视频 | 精品一区二区三区中文字幕 | 黑人精品欧美一区二区蜜桃 | 亚洲精品久久区二区三区蜜桃臀 | 国产高清视频在线观看 | 久久久天天 | 欧美日韩在线一区二区 | 成人a视频 | 午夜精品久久久久久久久久久久 |