精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

從零搭建一款PC頁(yè)面編輯器PC-Dooring

系統(tǒng) Linux
沒有太多時(shí)間做PC端搭建化項(xiàng)目, 好在搭建平臺(tái)很多原理都是通用的, 所以早在去年我就開發(fā)好了面向PC端的編輯器PC-Dooring, 雖然在設(shè)計(jì)上還有些不足(在后面的內(nèi)容中會(huì)提到) , 但是基本模型已經(jīng)實(shí)現(xiàn), 接下來(lái)就和大家一起分享一下具體的實(shí)現(xiàn).

[[392395]]

之前一直忙著調(diào)研l(wèi)owcode平臺(tái)和開發(fā)以下兩個(gè)項(xiàng)目:

  • H5編輯器H5-Dooring ,
  • 可視化大屏編輯器V6.Dooring

沒有太多時(shí)間做PC端搭建化項(xiàng)目, 好在搭建平臺(tái)很多原理都是通用的, 所以早在去年我就開發(fā)好了面向PC端的編輯器PC-Dooring, 雖然在設(shè)計(jì)上還有些不足(在后面的內(nèi)容中會(huì)提到) , 但是基本模型已經(jīng)實(shí)現(xiàn), 接下來(lái)就和大家一起分享一下具體的實(shí)現(xiàn).

為了保證文章整體的邏輯性和條理性, 我將可視化搭建平臺(tái)的具體的實(shí)現(xiàn)劃分為了以下幾個(gè)部分:

  • PC編輯器效果展示
  • 整體技術(shù)架構(gòu)
  • 可視化搭建技術(shù)實(shí)現(xiàn)方式
  • 編輯器核心思路
  • 編輯器架構(gòu)模型
  • 如何開發(fā)標(biāo)準(zhǔn)物料組件
  • 編輯器后期規(guī)劃

PC編輯器效果展示

pc-dooring

在上面的演示中, 組件庫(kù)方式和H5-Dooring類似, 只不過(guò)組件庫(kù)筆者采用了PC端專屬的組件庫(kù)antd, 所以我們可以將antd支持的任何組件集成進(jìn)PC-Dooring.

整體技術(shù)架構(gòu)

整體技術(shù)架構(gòu)和H5-Dooring類非常相似, 也是遵循筆者的產(chǎn)品設(shè)計(jì)哲學(xué)—— 不要讓用戶思考. 降低一切拖拽復(fù)雜度, 采用智能網(wǎng)格的交互模式來(lái)實(shí)現(xiàn)(這種設(shè)計(jì)方式有一定的局限, 僅供大家參考, 當(dāng)然也可以使用V6.Dooring的自由布局模式). 整體架構(gòu)如下圖所示:

 

image.png

由上圖我們可以看出編輯器主要分為如下幾個(gè)部分:

  • 組件物料
  • 畫布區(qū)
  • 屬性編輯區(qū)
  • 功能輔助
  • 其他

目前組件物料主要實(shí)現(xiàn)了基礎(chǔ)組件, 可視化組件和 媒體組件, 其他類的組件實(shí)現(xiàn)也類似, 技術(shù)整體實(shí)現(xiàn)我們會(huì)在下面介紹.

可視化搭建技術(shù)實(shí)現(xiàn)方式

image.png

前端框架我們還是使用的React, 當(dāng)然大家也可以使用Vue3.0, 原理都是相通的, 不同插件之間也提供了多框架的支持. 編輯器核心的一環(huán)就是組件拖拽, 這里筆者使用了社區(qū)比較強(qiáng)大且穩(wěn)定的庫(kù)react-dnd, 其拖拽分為兩個(gè)部分, 一個(gè)是從組件區(qū)拖拽到畫布區(qū), 另一個(gè)是畫布區(qū)內(nèi)部組件的自由拖拽. 我們可以用原生H5的拖放API來(lái)實(shí)現(xiàn)第一部分的功能, 本質(zhì)是將拖動(dòng)源攜帶的數(shù)據(jù)傳到畫布制定區(qū)域, 目標(biāo)源監(jiān)聽事件拿到攜帶的數(shù)據(jù)動(dòng)態(tài)渲染出實(shí)際的組件. 過(guò)程如下:

image.png

當(dāng)然深入研究過(guò)react-dnd的朋友都知道, 以上兩個(gè)功能通過(guò)react-dnd都可以實(shí)現(xiàn), 大家可以參考它的官網(wǎng)react-dnd官網(wǎng)學(xué)習(xí)研究具體實(shí)現(xiàn)流程, 也可以直接參考PC-Dooring源碼.

至于組件庫(kù), 我們可以采用任何我們熟悉的組件庫(kù), 比如antd, element, zant等, 組件物料需要遵循我們約定的DSL協(xié)議, 這里大家可以參考工業(yè)級(jí)協(xié)議標(biāo)準(zhǔn)odata規(guī)范. 有了一定的規(guī)范, 我們就可以包裝標(biāo)準(zhǔn)的組件物料從而集成第三方組件庫(kù)了.

至于功能輔助模塊和狀態(tài)管理, 我們可以采用如mobx, redux, dva等來(lái)實(shí)現(xiàn), 最終目的就是讓編輯器不同部分能相互關(guān)聯(lián), 實(shí)時(shí)更新組件狀態(tài), 以及數(shù)據(jù)回傳能力.

編輯器核心思路

編輯器核心實(shí)現(xiàn)思路筆者之前也分析了幾個(gè)現(xiàn)有方案, 發(fā)現(xiàn)字節(jié)魔方的思路很貼切, 這里附上一個(gè)原理圖:

image.png

核心就是通過(guò)編輯器產(chǎn)生的有效詞法數(shù)據(jù), 讓渲染器能解析渲染成可用的HTML頁(yè)面.

編輯器整體架構(gòu)模型

編輯器整體架構(gòu)模型主要是為了讓大家全局的了解可視化編輯器的實(shí)現(xiàn)思路, 以及未來(lái)的規(guī)劃方向, 筆者做了一個(gè)基本的草圖, 如下:

image.png

如何開發(fā)標(biāo)準(zhǔn)物料組件

開發(fā)標(biāo)準(zhǔn)組件物料需要遵循我們編輯器內(nèi)部的數(shù)據(jù)協(xié)議和組件開發(fā)規(guī)范, 在PC-Dooring中開發(fā)組件主要由以下幾部分組成:

  • 組件代碼
  • schema定義
  • template定義

組件代碼就是組件內(nèi)部具體的實(shí)現(xiàn), 如下案例:

  1. import React, { memo } from 'react'
  2. import { ITextConfig } from './schema'
  3. import logo from '@/assets/text.png'
  4. const Text = memo((props: ITextConfig & { isTpl: boolean }) => { 
  5.   const { align, text, fontSize, color, lineHeight, isTpl } = props; 
  6.   return ( 
  7.     <> 
  8.       {isTpl ? ( 
  9.         <div> 
  10.           <img src={logo} alt=""></img> 
  11.         </div> 
  12.       ) : ( 
  13.         <div style={{ color, textAlign: align, fontSize, lineHeight }}>{text}</div> 
  14.       )} 
  15.     </> 
  16.   ); 
  17. }); 
  18. export default Text; 

 schema定義了組件的屬性約束, 可編輯項(xiàng)類型以及默認(rèn)值, 如下:

  1. import { 
  2.   IColorConfigType, 
  3.   INumberConfigType, 
  4.   ISelectConfigType, 
  5.   ITextConfigType, 
  6.   TColorDefaultType, 
  7.   TNumberDefaultType, 
  8.   TSelectDefaultType, 
  9.   TTextDefaultType, 
  10. from '@/components/FormComponents/types'
  11.  
  12. export type TTextSelectKeyType = 'left' | 'right' | 'center'
  13. export type TTextEditData = Array< 
  14.   ITextConfigType | IColorConfigType | INumberConfigType | ISelectConfigType<TTextSelectKeyType> 
  15. >; 
  16. export interface ITextConfig { 
  17.   text: TTextDefaultType; 
  18.   color: TColorDefaultType; 
  19.   fontSize: TNumberDefaultType; 
  20.   align: TSelectDefaultType<TTextSelectKeyType>; 
  21.   lineHeight: TNumberDefaultType; 
  22.  
  23. export interface ITextSchema { 
  24.   editData: TTextEditData; 
  25.   config: ITextConfig; 
  26. const Text: ITextSchema = { 
  27.   editData: [ 
  28.     { 
  29.       key'text'
  30.       name'文字'
  31.       type: 'Text'
  32.     }, 
  33.     { 
  34.       key'color'
  35.       name'標(biāo)題顏色'
  36.       type: 'Color'
  37.     }, 
  38.     { 
  39.       key'fontSize'
  40.       name'字體大小'
  41.       type: 'Number'
  42.     }, 
  43.     { 
  44.       key'align'
  45.       name'對(duì)齊方式'
  46.       type: 'Select'
  47.       range: [ 
  48.         { 
  49.           key'left'
  50.           text: '左對(duì)齊'
  51.         }, 
  52.         { 
  53.           key'center'
  54.           text: '居中對(duì)齊'
  55.         }, 
  56.         { 
  57.           key'right'
  58.           text: '右對(duì)齊'
  59.         }, 
  60.       ], 
  61.     }, 
  62.     { 
  63.       key'lineHeight'
  64.       name'行高'
  65.       type: 'Number'
  66.     }, 
  67.   ], 
  68.   config: { 
  69.     text: '我是文本'
  70.     color: 'rgba(60,60,60,1)'
  71.     fontSize: 18, 
  72.     align: 'center'
  73.     lineHeight: 2, 
  74.   }, 
  75. }; 
  76. export default Text; 

template主要規(guī)定了組件在畫布中展示的基本方式, 如下:

  1. const template = { 
  2.   type: 'Text'
  3.   h: 20, 
  4.   displayName: '文本組件'
  5. }; 
  6. export default template; 

當(dāng)然大家也可以擴(kuò)展其定義或者將schema和template合并. 只要一個(gè)組件符合了以上約定, 都可以被我們編輯器所消費(fèi).

編輯器后期規(guī)劃

PC編輯器目前仍存在一些問(wèn)題沒有很好的解決, 比如布局方式的局限性導(dǎo)致必須橫向擴(kuò)展很多組件才能滿足不同用戶的個(gè)性化需求, 其次就是組件聯(lián)動(dòng)機(jī)制, 需要統(tǒng)一數(shù)據(jù)中心來(lái)管理, 后面會(huì)在H5-Dooring 中展示具體的實(shí)現(xiàn)方式, 大家感興趣也可以實(shí)現(xiàn)一下.

目前PC-Dooring已經(jīng)在github上以MIT協(xié)議完全開源, 如果大家感興趣,也可以貢獻(xiàn)你的一份力量, 幫助社區(qū)解決更多問(wèn)題.

 

責(zé)任編輯:姜華 來(lái)源: 趣談前端
相關(guān)推薦

2021-08-26 05:15:22

圖片編輯器 H5-DooringMitu-Doorin

2022-08-31 08:32:22

數(shù)據(jù)可視化項(xiàng)目nocode

2021-06-22 14:47:19

electronDooring架構(gòu)

2024-03-06 08:26:29

2021-11-24 09:12:11

Markdown編輯器Linux

2021-09-11 21:03:09

可視化搭建框架

2021-09-14 08:38:57

組件開源前端

2020-09-16 10:27:50

MarkDown編輯器編程

2022-09-05 13:16:42

MicroVim編輯器

2019-05-30 08:43:45

JavaScript富文本編輯器編輯器

2021-02-20 07:02:24

Vue.js組件開發(fā)技術(shù)

2023-01-07 08:09:41

零代碼Dooring組件

2021-04-08 14:58:59

開發(fā)前端編輯器

2023-06-20 00:04:18

框架開發(fā)UMD

2021-01-27 07:24:38

TypeScript工具Java

2016-08-10 14:59:41

前端Javascript工具

2015-02-12 09:51:24

代碼編輯

2021-03-10 09:15:15

代碼文本編輯器編程

2020-12-29 05:26:27

視頻播放器Vuevideo

2021-03-08 06:00:03

Markdown在線編輯器開源
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

日韩成人影音| 亚洲精品一区二区口爆| 欧美一站二站| 91精品免费在线| 国产又粗又长又爽视频| 人妻视频一区二区三区| 久久精品盗摄| www.久久久久| 国产日韩视频一区| 中文在线最新版地址| 亚洲国产成人一区二区三区| 成人在线国产精品| 亚洲日本韩国在线| 久久精品亚洲人成影院| 日韩av影视在线| 一区二区三区欧美精品| 国产黄大片在线观看| 国产日韩欧美激情| 国产精品日韩一区二区| 在线免费观看视频网站| 亚洲青色在线| 久久久国产视频| 一区二区不卡免费视频| 年轻的保姆91精品| 欧美中文字幕一二三区视频| 国产精品69久久久| 国产91在线视频蝌蚪| 久久久亚洲国产美女国产盗摄 | 特一级黄色大片| 婷婷成人基地| 影音先锋日韩有码| 亚洲一区二区三区无码久久| 成人免费91| 欧美午夜一区二区| 日日摸日日碰夜夜爽av| 亚洲国产精品精华素| 亚洲国产精品t66y| 欧美连裤袜在线视频| 欧美 中文字幕| 狠狠久久亚洲欧美| 国产精品流白浆视频| 日产精品久久久| 国产精品v亚洲精品v日韩精品 | 首页欧美精品中文字幕| 欧美精品videosex牲欧美| 91香蕉视频污在线观看| 精品在线观看入口| 亚洲欧美国产一区二区三区| 怡红院一区二区| 中文在线综合| 日韩一区二区三区观看| 亚洲视频一二三四| 国产亚洲人成a在线v网站 | 中文字幕观看在线| 肉色丝袜一区二区| 国产精品成人v| www.国产毛片| 日韩va欧美va亚洲va久久| 日本欧美国产在线| 无码任你躁久久久久久久| 亚洲一区免费| 热久久免费视频精品| 亚洲AV无码成人精品区东京热| 亚洲美女网站| 91精品国产高清| 东京热一区二区三区四区| 亚洲在线视频| 国产精品r级在线| 中文字幕 国产| 另类小说综合欧美亚洲| 亚洲精品欧美日韩专区| 国产美女免费视频| 成人免费黄色大片| 免费观看国产成人| 激情小视频在线观看| 国产欧美精品在线观看| 亚洲一二三区精品| 91在线中文| 亚洲成人综合网站| 国语对白做受xxxxx在线中国| 色尼玛亚洲综合影院| 欧美日韩一区三区| 久久aaaa片一区二区| 91大神精品| 精品亚洲一区二区三区在线观看| 男人操女人动态图| 日韩精品一区二区三区免费观影| 久久精品久久久久| 国产一级中文字幕| 久久精品官网| 国产欧美精品一区二区| 成人h动漫精品一区二区无码| 岛国精品一区二区| 欧美日韩国产综合在线| 蜜桃视频在线观看www社区 | 日韩中文av在线| 欧美被狂躁喷白浆精品| 国产一区二区三区久久| 国产精品嫩草影院一区二区 | 精品国产一区二区三区久久久蜜月| 中文字幕在线观看91| 蜜桃视频欧美| 九九久久国产精品| 亚洲不卡视频在线观看| 精品一区二区日韩| 久久riav二区三区| 欧洲不卡视频| 欧美色视频日本高清在线观看| 久久国产激情视频| 亚洲v天堂v手机在线| 久久久国产精彩视频美女艺术照福利| 亚洲精品www久久久久久| 麻豆精品国产传媒mv男同| 国产在线精品一区二区三区》| avtt亚洲| 日韩欧美亚洲一二三区| 69久久精品无码一区二区| 久久99高清| 久久久免费电影| 怡春院在线视频| 99久久精品国产一区二区三区| 婷婷视频在线播放| 亚洲欧洲自拍| 欧美精品一区二区在线播放| 日本少妇aaa| 久久综合九色综合欧美狠狠| 国产91视觉| 久操免费在线| 欧美丝袜第三区| 丝袜美腿中文字幕| 禁久久精品乱码| 成人亲热视频网站| av在线天堂播放| 狠狠躁夜夜躁久久躁别揉| 欧美熟妇精品一区二区| 91日韩在线| 国产精品亚洲综合天堂夜夜| 欧美一区二区三区少妇| 天天色天天爱天天射综合| 美女日批在线观看| 亚洲国产精品久久久久蝴蝶传媒| 国产精品日日做人人爱 | 色先锋资源久久综合5566| 在线免费黄色av| 99久久免费精品| 欧美精品久久久久久久自慰| 亚洲国产欧美在线观看| 欧美老女人xx| 精品人妻一区二区三区三区四区| 国产精品美女久久久久久久久| 国产精品无码av无码| 久久99久久人婷婷精品综合| 日韩免费在线观看视频| 韩国三级在线观看久| 日韩欧美精品在线观看| 美女被到爽高潮视频| 日韩成人精品视频| 亚洲高清不卡一区| 久久亚洲人体| 久久天天躁狠狠躁夜夜躁| 97人妻精品一区二区三区动漫| 国产精品久久久久久久久久免费看 | 欧美性猛交xxx乱大交3蜜桃| 欧美三级欧美一级| 国产精品久久国产精麻豆96堂| 久久成人免费电影| 精品一区二区三区毛片| 6080成人| 4438全国亚洲精品在线观看视频| 欧美色综合一区二区三区| 91黄色免费观看| 永久免费观看片现看| 极品少妇一区二区三区精品视频 | 最新成人av网站| 久久99国产精品| 深夜视频一区二区| 久久精品色欧美aⅴ一区二区| 国产同性人妖ts口直男| 亚洲亚洲人成综合网络| 中文字幕一区二区三区人妻电影| 久久九九99| 一区二区三视频| 天堂av一区| 久久久亚洲精选| 欧美日本韩国一区二区| 欧美日韩成人在线一区| 久久久久久久久久久久久久免费看| 不卡av免费在线观看| 国模杨依粉嫩蝴蝶150p| 影音先锋日韩精品| 精品欧美国产| 色诱色偷偷久久综合| 久久男人资源视频| 成年人视频免费在线观看| 欧美一级高清大全免费观看| 91porny在线| 成人欧美一区二区三区小说 | 国产精品私人自拍| 在线播放av网址| 蜜臀va亚洲va欧美va天堂| 九一免费在线观看| 精品国产乱码久久久久久果冻传媒| 91久久精品视频| 爱情电影社保片一区| 中文字幕在线亚洲| 四虎在线免费看| 91精品在线观看入口| 黑人精品无码一区二区三区AV| 成人欧美一区二区三区在线播放| 黄色正能量网站| 久久精品二区亚洲w码| 欧美三级一级片| 午夜裸体女人视频网站在线观看| 99久久综合色| 天天干天天草天天| 国产美女一区| 国产精品va在线观看无码| 在线免费观看黄色网址| 在线播放91灌醉迷j高跟美女 | 亚洲有吗中文字幕| 欧洲亚洲一区二区| 嫩草国产精品入口| yellow视频在线观看一区二区 | 在线观看视频一区二区| 九九九国产视频| 亚洲欧美日韩国产中文在线| 亚洲理论片在线观看| 不卡高清视频专区| 亚洲一级Av无码毛片久久精品| 麻豆成人久久精品二区三区红 | 激情综合亚洲精品| 国产性生交xxxxx免费| 99热精品在线| 波多野结衣av一区二区全免费观看| 欧美韩日一区| 亚洲电影网站| 欧美一区2区| 神马一区二区影院| 国产探花一区二区| 欧美一区1区三区3区公司| 香蕉久久精品日日躁夜夜躁| 国产精品免费看一区二区三区| 日韩精品一区国产| 亚洲xxxx18| 一区二区免费| 国产精品嫩草在线观看| 超碰97久久| 国产精品麻豆免费版| 国产伦精品一区二区三区在线播放| 91超碰在线免费观看| 精品国产乱码一区二区三区| 成人免费午夜电影| 免费观看性欧美大片无片| 亚洲淫片在线视频| 亚洲一区二区三区中文字幕在线观看| 亚洲综合在线做性| 成人福利一区| 精品无人区一区二区三区| 日韩伦理一区二区三区| 蜜桃日韩视频| 日韩av久操| 强伦女教师2:伦理在线观看| 亚洲精品a级片| 国产一区 在线播放| 精品电影一区| 无码aⅴ精品一区二区三区浪潮| 美女久久网站| 精品综合久久久久| 国产成人免费视频精品含羞草妖精| 国产成人精品综合久久久久99 | 国产精品美女高潮无套| 欧美国产日韩在线观看| 久久福利免费视频| 亚洲综合在线五月| 丁香社区五月天| 欧美日韩精品福利| 亚洲国产精品欧美久久| 日韩精品亚洲元码| 91caoporn在线| 欧美日韩国产成人高清视频| 国产精品yjizz视频网| 日本一区二区不卡| 欧美a一级片| 国产精品一区二区三区在线| 亚洲女娇小黑人粗硬| 亚洲欧洲一二三| 欧美网站在线| 一本色道无码道dvd在线观看| 韩国精品在线观看| 国产伦精品一区三区精东| 国产欧美一区二区在线| 清纯粉嫩极品夜夜嗨av| 色一情一伦一子一伦一区| 国产伦精品一区二区三区视频痴汉 | 免费一区二区三区在线观看 | 欧美久久久一区| 内射后入在线观看一区| 一区二区三区视频观看| 亚洲欧美成人影院| 国产精品高潮呻吟视频| 91精品久久久久久综合五月天| 热舞福利精品大尺度视频| 综合精品一区| 欧美性猛交xxx乱久交| 粉嫩一区二区三区性色av| 欧美 日韩 国产 成人 在线观看| 一区二区在线免费| 国产在线一级片| 精品免费视频一区二区| 91最新在线| 欧洲亚洲免费在线| 1204国产成人精品视频| 亚洲欧美日韩国产yyy| 一本久久知道综合久久| 亚洲欧美日韩一二三区| 国产区在线观看成人精品| 五月天婷婷网站| 欧美一区二区三区免费在线看| 黄色av网站在线免费观看| 97视频网站入口| 日韩中文字幕| 亚洲精品永久www嫩草| 亚洲综合精品| 欧美无人区码suv| 亚洲一区二区精品视频| 国产黄色片av| 久久精品电影网站| 精品女同一区二区三区在线观看| 精品国产综合久久| 亚洲无线视频| 在线中文字日产幕| 一区二区三区成人| 国产免费福利视频| 精品国产拍在线观看| 精品欧美日韩精品| 欧洲一区二区在线观看| 美女被久久久| 熟女俱乐部一区二区| 日韩欧美精品免费在线| 日韩一区av| 日本精品久久中文字幕佐佐木| 日韩成人一级| 亚洲 高清 成人 动漫| 成人av网站在线| 日韩三级av在线| 亚洲精品不卡在线| 久草在线资源福利站| 国产在线一区二区三区欧美| 亚洲国产高清一区| 国产精品久久AV无码| 黄色一区二区三区| 天堂在线中文字幕| 1769国产精品| 久草精品在线| 欧美大尺度做爰床戏| 国产精品久久久久久久久动漫| 一级特黄色大片| 操91在线视频| 国产精品男女| 欧美性久久久久| 欧美国产综合一区二区| 一区不卡在线观看| 久久久电影免费观看完整版| 日本在线成人| 男人的天堂狠狠干| 久久久久久久电影| 最近中文字幕免费在线观看| 日韩一区二区福利| 日本高清久久| 成人综合视频在线| 欧美经典一区二区| 国产熟女一区二区丰满| 国模私拍一区二区三区| 亚洲系列另类av| 亚洲一级免费在线观看| 亚洲视频一区在线观看| 丰满少妇一级片| 国产成人aa精品一区在线播放| 欧美综合在线视频观看| 亚洲第一天堂久久| 亚洲成a人v欧美综合天堂下载| 蜜桃免费在线| 91亚洲精品视频| 中文一区二区| 三级影片在线观看| 日韩av影片在线观看| 福利一区二区免费视频| 欧美日韩激情四射| 久久美女高清视频| av观看在线免费| 欧美一区二区三区艳史| 午夜精品毛片| 无码人妻精品一区二区三区温州| 欧美日韩1区2区| 精精国产xxxx视频在线播放| 亚洲一区二区三区加勒比| www..com久久爱| 一区二区日韩视频| 欧美一区二区三区免费观看| 久久久久久美女精品 |