主頁 > 企業開發 > 決議Markdown檔案生成React組件檔案

決議Markdown檔案生成React組件檔案

2021-09-23 10:04:35 企業開發

前言

最近做的專案使用了微前端框架single-spa,

對于這類微前端框架而言,通常有個utility應用,也就是公共應用,里面是各個子應用之間可以共用的一些公共組件或者方法,

對于一個團隊而言,專案中公共組件和方法的使用難點不在于封裝不在于技術,很多時候在于團隊內部成員是否都能了解這些組件,以避免重復開發,從而提升團隊效率,

如果是團隊比較小,人員比較穩定的專案組可能還好點,對于團隊比較大,人員流動較快的團隊,這些通用組件和方法往往就被人遺忘在角落,很難再得到有效利用,

因為我所在的專案還在開發初期,并且是新入職也想去熟悉一下當前專案中的一些通用組件和方法,所以我自己特意開發了一個檔案應用去解決這個問題,

技術方案選型

對于一個面向Ant Design編程的咸魚而言,這個檔案應用肯定是往這個方向做,

目標是能做成Ant Design的組件檔案那樣好用,既能很快看清組件的使用效果,也能快速復制示例代碼,

有了目標之后,很快選定了兩個技術方案

  • StoryBook方案
  • 自己開發決議markdown檔案的檔案應用

StoryBook是市面上一款比較流行的構建UI組件和檔案的庫,功能很強大,

但是這個庫如果要應用到我們專案的團隊存在以下問題:

  • 英文檔案,有學習成本
  • 引入single-spa的utility應用很麻煩
  • 對于構建在utility應用中的組件,需要在StoryBook中再寫一遍,容易不同步
  • 對于通用方法可能不支持

尤其是第三點特別存在問題,團隊成員大都是業務開發,有交付壓力,不是在github上為愛發電的開源貢獻者,

他們是否有意愿在utility應用中寫了一遍組件代碼后,又專門跑到這個StoryBook中再寫一道?

如果組件代碼修改后,StoryBook這邊沒修改,這種不同步很容易導致開發人員明明按照檔案使用組件,但是組件就是報錯,挫敗感很強,

聯系到現實,我已經預想到如果走這個方案,一個月內這個玩意就會名存實亡,成為形式主義的存在,在三個月后成為大家都不愿提起的垃圾了,

所以有了第二個方案的誕生:自己開發決議markdown檔案的檔案應用

這個方案并不是我憑空想象出來的,而是在前公司中就有這么一個內部應用,組件開發人員自己撰寫markdown檔案,最終生成組件檔案,并且應用本身可以決議markdown檔案中的代碼部分,從而在組件檔案中生成對應的組件示例,

彼時我只是一個組件開發人員,并不是這個檔案應用的實作人員,所以也不知道其技術原理,

但是前公司這個應用讓我知道了這么玩行得通,當時作為組件開發人員,接受和使用這個應用例外輕松,只要會寫markdown就行了,沒有學習成本,而且使用這種方式,控制權掌握在自己手中,更容易和自己的團隊專案有效結合起來,

基本原理

雖然這個檔案應用是我一個人花了兩天的時間獨立完成,但是花的是作業時間,完成后也是公司內部專案,所以這個檔案應用我沒法開源出來,

不過我可以告訴大家一個主要思路和步驟,想必復現出來也并不困難,

第一步讓我們搞定這個專案的框架,

因為需要引入single-spa的utility應用,所以框架我直接用的是single-spa的基座,并且專案內含一個子應用用于展示檔案,而utility應用直接引入線上開發環境的utility應用,避免團隊成員重復書寫組件代碼,也解決了檔案和實際應用不同步的問題,

通過這一步,我們解決了StoryBook方案中的痛點2和痛點3,

第二步我們需要載入markdown檔案,

這一步肯定是通過webpack的加載器來做處理,這些加載器有的比較強大,可以直接將markdown檔案轉換為html,但是我并沒有選擇這種,而是直接用的raw-loader,將我們的markdown檔案轉換為字串載入,

代碼大致如下,這個比較簡單,就不說了,

module.exports = {
    module: {
        rules: [
            {
                test: /\.md$/,
                use: 'raw-loader'
            }
        ]
    }
}

第三步我們需要決議markdown檔案生成檔案,并決議其中的React組件,生成組件示例,

決議markdown檔案轉換為html檔案,實際上有個比較強大的庫,叫Showdown,

而我所用到的庫react-showdown則是對Showdown的進一步封裝,可以借助一個react組件將markdown和包含在markdown檔案中的react組件渲染成html,

下面是它的一個官方示例:

import React from 'react';
import MarkdownView from 'react-showdown';

export default function App() {
    const markdown = `
    # Welcome to React Showdown :+1:

    To get started, edit the markdown in \`example/src/App.tsx\`.

    | Column 1 | Column 2 |
    |----------|----------|
    | A1       | B1       |
    | A2       | B2       |
    `;

    return (
        <MarkdownView
        markdown={markdown}
        options={{ tables: true, emoji: true }}
        />
    );
};

通過MarkdownView這個組件,可以將一串markdown格式的文本轉化為html,

另外我們注意到它的選項,tables為true,如果不設定這個的話,markdown中的table格式將不會被轉化成表格,第二個emoji為true是支持emoji轉換,

這個時候你可能要問,這只是轉換了一下markdown檔案而已,轉換react組件呢?

我們可以看一下下面這個官方示例:

import MarkdownView from 'react-showdown';

function CustomComponent({ name }: { name: string }) {
    return <span>Hello {name}!</span>;
}

const markdown = `
# 我是個標題:

<CustomComponent name="world" />`;

<MarkdownView markdown={markdown} components={{ CustomComponent }} />

在markdown文本中可以直接寫上CustomComponent這個自定義的react組件代碼,然后在MarkdownView的components中傳入CustomComponent即可,

生成的最終html中不僅會有個標題,標題下面還會展示一個叫hello world!的文本,而不是展示<CustomComponent name="world" />這個字串,

排疑解難

看完了上面的原理,想必您已經可以實作這樣的一個檔案應用了,

不過在這個程序中您可能還是會遇到一些小麻煩,這里提前給您支個招,

麻煩1:markdown轉換成html后的代碼高亮處理,

因為我們做的是一個組件檔案,那么肯定會涉及到代碼展示,

markdown檔案中的代碼塊,使用react-showndown轉換后的并沒有做高亮處理,

不過react-showdown是支持Showdown的各種擴展的,其中有個擴展叫showdown-highlight,通過這個擴展可以對代碼塊做高亮處理,

麻煩2react-showndown只支持簡單的組件,

雖然react-showndown可以決議react組件代碼,但是它也只能簡單決議這個組件,如果我們演示的示例比較復雜,涉及到一些函式,還有一些庫的參考,很顯然不能再markdown檔案中直接寫,

這里我建議直接將每個組件的示例寫到一個獨立的js中,這個js匯出一個Demo組件,然后我們在markdown檔案中直接參考這個demo組件即可,

大致代碼如下:

import MarkdownView from 'react-showdown';
import ButtonDemo from './ButtonDemo';

const markdown = `
# 按鈕組件

組件描述

## 代碼示例

<ButtonDemo />

```tsx
這里貼出以ButtonDemo組件中的代碼
```

## API

| 屬性     | 說明      |XXX|
|----------|----------|-----|
| title    | 按鈕文本  | XXX |
| type     | 按鈕型別  | XXX |

`;

<MarkdownView markdown={markdown} components={{ ButtonDemo }} />

通過上面這種方式,不論我們ButtonDemo中的邏輯和功能多么復雜,展示出來都是沒問題的,

麻煩3:如何將這個檔案應用做到簡單好用,

看了上面的代碼,可能有人會覺得應該沒問題了,

但是我們得明白,我們這個東西是做給業務開發的人員用的,而不是做給我們自己用的,

我業務開發人員為什么要知道你這些什么 react-showdown 的代碼?

我業務開發人員還要學習你的這些鬼東西?

不是每個人都想著學這些亂七八糟的技術好嗎?

我每天就只想在6點下班,就算你5分鐘內給我講明白了,你這個檔案應用我用不用還兩說,

你要是5分鐘之內還講不明白怎么用,那你休想我在這上面給一個公共組件寫檔案,

我們面對的基本就是這么一個場景,我們做這個應用是為了解決專案中實際面臨的問題,是面向業務開發人員編程,而不是面向領導和KPI編程,

所以我們需要做到簡單好用,將所有涉及到react-showdown這玩意的部分全部不被業務開發人員感知,

想象一下,寫一個組件的檔案,縮減到最少,就是一個markdown檔案,和一個demo.js,

那么我們就只讓業務開發人員去寫這兩個東西就行,把他們的作業量減少到最小,

就給他們兩個檔案夾,一個檔案夾叫doc,里面放markdown檔案,一個檔案夾叫demo,里面放各個demo,

再用一個字典配置dict.js,去做個基本的配置,

如果現在有個Easy組件要寫檔案,那么我們的dict.js內容可能就是下面這樣:

const dict=['Easy','Hard','XXX']

export defalt dict

只需要加個字串Easy即可,

然后你可以在那么doc檔案夾下加個markdown檔案叫EasyMD.md,demo檔案夾下加個檔案叫EasyDemo.tsx,

之后的所有步驟全部由我們的檔案應用決議dict.js后自動完成,無需用戶操心,

通過這樣的一種約定,我們可以將業務開發人員的作業量減到最小,把他們寫組件檔案的門檻降到最低,

具體代碼實作就略過了,實作的關鍵詞叫:import()函式,其他的不用多說了,

總結

雖然說這個檔案應用是受前公司啟發,而且因為開發時間就兩天,所以比較簡陋,但是至少我做到了比前公司的內部應用更簡單方便,完全沒有學習成本,

好了,自吹一波就得了,本篇博客到此結束,

如有疏漏之處,還請不吝賜教,

作者:韓子盧
出處:https://www.cnblogs.com/vvjiang/
本博客文章均為作者原創,轉載請注明作者和原文鏈接,

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/302146.html

標籤:JavaScript

上一篇:jQuery-02

下一篇:vue實作列印、批量列印

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • IEEE1588PTP在數字化變電站時鐘同步方面的應用

    IEEE1588ptp在數字化變電站時鐘同步方面的應用 京準電子科技官微——ahjzsz 一、電力系統時間同步基本概況 隨著對IEC 61850標準研究的不斷深入,國內外學者提出基于IEC61850通信標準體系建設數字化變電站的發展思路。數字化變電站與常規變電站的顯著區別在于程序層傳統的電流/電壓互 ......

    uj5u.com 2020-09-10 03:51:52 more
  • HTTP request smuggling CL.TE

    CL.TE 簡介 前端通過Content-Length處理請求,通過反向代理或者負載均衡將請求轉發到后端,后端Transfer-Encoding優先級較高,以TE處理請求造成安全問題。 檢測 發送如下資料包 POST / HTTP/1.1 Host: ac391f7e1e9af821806e890 ......

    uj5u.com 2020-09-10 03:52:11 more
  • 網路滲透資料大全單——漏洞庫篇

    網路滲透資料大全單——漏洞庫篇漏洞庫 NVD ——美國國家漏洞庫 →http://nvd.nist.gov/。 CERT ——美國國家應急回應中心 →https://www.us-cert.gov/ OSVDB ——開源漏洞庫 →http://osvdb.org Bugtraq ——賽門鐵克 →ht ......

    uj5u.com 2020-09-10 03:52:15 more
  • 京準講述NTP時鐘服務器應用及原理

    京準講述NTP時鐘服務器應用及原理京準講述NTP時鐘服務器應用及原理 安徽京準電子科技官微——ahjzsz 北斗授時原理 授時是指接識訓通過某種方式獲得本地時間與北斗標準時間的鐘差,然后調整本地時鐘使時差控制在一定的精度范圍內。 衛星導航系統通常由三部分組成:導航授時衛星、地面檢測校正維護系統和用戶 ......

    uj5u.com 2020-09-10 03:52:25 more
  • 利用北斗衛星系統設計NTP網路時間服務器

    利用北斗衛星系統設計NTP網路時間服務器 利用北斗衛星系統設計NTP網路時間服務器 安徽京準電子科技官微——ahjzsz 概述 NTP網路時間服務器是一款支持NTP和SNTP網路時間同步協議,高精度、大容量、高品質的高科技時鐘產品。 NTP網路時間服務器設備采用冗余架構設計,高精度時鐘直接來源于北斗 ......

    uj5u.com 2020-09-10 03:52:35 more
  • 詳細解讀電力系統各種對時方式

    詳細解讀電力系統各種對時方式 詳細解讀電力系統各種對時方式 安徽京準電子科技官微——ahjzsz,更多資料請添加VX 衛星同步時鐘是我京準公司開發研制的應用衛星授時時技術的標準時間顯示和發送的裝置,該裝置以M國全球定位系統(GLOBAL POSITIONING SYSTEM,縮寫為GPS)或者我國北 ......

    uj5u.com 2020-09-10 03:52:45 more
  • 如何保證外包團隊接入企業內網安全

    不管企業規模的大小,只要企業想省錢,那么企業的某些服務就一定會采用外包的形式,然而看似美好又經濟的策略,其實也有不好的一面。下面我通過安全的角度來聊聊使用外包團的安全隱患問題。 先看看什么服務會使用外包的,最常見的就是話務/客服這種需要大量重復性、無技術性的服務,或者是一些銷售外包、特殊的職能外包等 ......

    uj5u.com 2020-09-10 03:52:57 more
  • PHP漏洞之【整型數字型SQL注入】

    0x01 什么是SQL注入 SQL是一種注入攻擊,通過前端帶入后端資料庫進行惡意的SQL陳述句查詢。 0x02 SQL整型注入原理 SQL注入一般發生在動態網站URL地址里,當然也會發生在其它地發,如登錄框等等也會存在注入,只要是和資料庫打交道的地方都有可能存在。 如這里http://192.168. ......

    uj5u.com 2020-09-10 03:55:40 more
  • [GXYCTF2019]禁止套娃

    git泄露獲取原始碼 使用GET傳參,引數為exp 經過三層過濾執行 第一層過濾偽協議,第二層過濾帶引數的函式,第三層過濾一些函式 preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'] (?R)參考當前正則運算式,相當于匹配函式里的引數 因此傳遞 ......

    uj5u.com 2020-09-10 03:56:07 more
  • 等保2.0實施流程

    流程 結論 ......

    uj5u.com 2020-09-10 03:56:16 more
最新发布
  • 使用Django Rest framework搭建Blog

    在前面的Blog例子中我們使用的是GraphQL, 雖然GraphQL的使用處于上升趨勢,但是Rest API還是使用的更廣泛一些. 所以還是決定回到傳統的rest api framework上來, Django rest framework的官網上給了一個很好用的QuickStart, 我參考Qu ......

    uj5u.com 2023-04-20 08:17:54 more
  • 記錄-new Date() 我忍你很久了!

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 大家平時在開發的時候有沒被new Date()折磨過?就是它的諸多怪異的設定讓你每每用的時候,都可能不小心踩坑。造成程式意外出錯,卻一下子找不到問題出處,那叫一個煩透了…… 下面,我就列舉它的“四宗罪”及應用思考 可惡的四宗罪 1. Sa ......

    uj5u.com 2023-04-20 08:17:47 more
  • 使用Vue.js實作文字跑馬燈效果

    實作文字跑馬燈效果,首先用到 substring()截取 和 setInterval計時器 clearInterval()清除計時器 效果如下: 實作代碼如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta ......

    uj5u.com 2023-04-20 08:12:31 more
  • JavaScript 運算子

    JavaScript 運算子/運算子 在 JavaScript 中,有一些運算子可以使代碼更簡潔、易讀和高效。以下是一些常見的運算子: 1、可選鏈運算子(optional chaining operator) ?.是可選鏈運算子(optional chaining operator)。?. 可選鏈操 ......

    uj5u.com 2023-04-20 08:02:25 more
  • CSS—相對單位rem

    一、概述 rem是一個相對長度單位,它的單位長度取決于根標簽html的字體尺寸。rem即root em的意思,中文翻譯為根em。瀏覽器的文本尺寸一般默認為16px,即默認情況下: 1rem = 16px rem布局原理:根據CSS媒體查詢功能,更改根標簽的字體尺寸,實作rem單位隨螢屏尺寸的變化,如 ......

    uj5u.com 2023-04-20 08:02:21 more
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 08:01:50 more
  • 如何在 vue3 中使用 jsx/tsx?

    我們都知道,通常情況下我們使用 vue 大多都是用的 SFC(Signle File Component)單檔案組件模式,即一個組件就是一個檔案,但其實 Vue 也是支持使用 JSX 來撰寫組件的。這里不討論 SFC 和 JSX 的好壞,這個仁者見仁智者見智。本篇文章旨在帶領大家快速了解和使用 Vu ......

    uj5u.com 2023-04-20 08:01:37 more
  • 【Vue2.x原始碼系列06】計算屬性computed原理

    本章目標:計算屬性是如何實作的?計算屬性快取原理以及洋蔥模型的應用?在初始化Vue實體時,我們會給每個計算屬性都創建一個對應watcher,我們稱之為計算屬性watcher ......

    uj5u.com 2023-04-20 08:01:31 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:01:10 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:00:32 more