頁面可視化搭建工具技術要點

背景

頁面可視化搭建工具, 是互聯網公司中常見的運營工具, 實現了運營人員快速生成和發佈頁面, 提高頁面上線效率; 且無需開發人員介入, 節省開發人力.javascript

頁面可視化搭建工具搭建出的頁面示例: html

但從零開始設計和開發出這種工具並不簡單. 筆者維護的頁面可視化搭建框架 pipeline, 提供了頁面可視化搭建的核心功能, 免去從零實現頁面可視化搭建工具的困難.前端

本文主要包含如下內容:vue

  • 活動頁面重複開發的痛點.
  • 開發可視化搭建工具的技術要點.
  • 理想的運營頁面可視化搭建工具.
  • 開源頁面搭建框架 pipeline 介紹.

活動頁面開發之痛

活動頁面特色

前端業務中, 常常須要開發產品介紹頁/營銷頁/活動頁/圖片展現頁等頁面. 這類需求有如下幾個特色:java

  • 頁面相似: 頁面佈局和業務邏輯較固定.
  • 需求高頻: 每週甚至天天有多個這種需求.
  • 迭代快速: 開發時間短, 上線時間緊.
  • 開發性價比低: 開發任務重複, 消耗各方的溝通時間和人力.

活動頁面常規開發流程

活動頁面常規開發流程圖

image

流程

  1. 運營/產品提出頁面需求.
  2. 走項目流程進入開發環節.
  3. 開發根據設計稿完成頁面開發.
  4. 測試進行頁面測試.
  5. 運維進行頁面上線.
  6. 運營/產品進行頁面驗收.

痛點

  • 方多參與, 反覆溝通, 串行流程.
  • 頁面上線週期長, 沒法快速響應活動需求.
  • 人力陷入重複工做泥潭, 忙碌而低效.

更優的流程

對於高頻和重複的活動頁面開發, 業界通常將頁面作成配置化, 配置工做從開發人員交接給產品/運營等需求方; 開發和設計人員只需提供配置化頁面支持. 更優的活動頁面生成流程依靠頁面可視化搭建系統來實現. 現.react

更優的活動頁面開發流程圖

image

流程

  1. 運營/產品提出頁面需求.
  2. 運營/產品在頁面可視化搭建系統中選取合適的頁面模板進行頁面搭建.
  3. 頁面自動化發佈上線, 頁面需求完成, 流程完結.
  4. 若是運營/產品沒有找到合適的模板.
  5. 開發進行頁面模板開發, 並將頁面模板添加到頁面可視化搭建系統中.
  6. 運營/產品繼續流程2.

同時, 隨着頁面可視化搭建系統中的頁面模板不斷豐富, 新的頁面需求對開發人員的依賴逐漸減低, 可由運營/產品直接完成.webpack

頁面可視化搭建工具

更優的活動頁面開發流程依靠頁面可視化搭建系統實現, 重點是要有頁面可視化搭建工具提供技術支持. 頁面可視化搭建工具經過填寫配置數據表單, 拖拉頁面組件等可視化的頁面編輯方式, 實現頁面的生成或修改.git

但從零開始設計和開發出頁面可視化搭建工具並不簡單, 有幾個須要瞭解和關注的技術點.github

頁面可視化搭建工具的技術要點

從技術角度, 設計和開發一個頁面可視化搭建工具時, 須要考慮如下幾個技術要點:web

  • 頁面組件化
  • 頁面模板
  • 頁面可視化編輯
  • 組件層級關係
  • 頁面打包
  • 實時預覽
  • 頁面組件開發

image

頁面組件化

組件化的優勢

頁面的基本單元是 HTML 元素, 可是 HTML 元素沒法包含業務邏輯, 且由 HTML 元素直接組合出頁面, 過於繁雜和低效.

image
圖片來源: vuejs.org/images/comp…

頁面較好的組織方式是組件化, 如上圖所示. 組件是對 HTML 元素、元素佈局和樣式、業務邏輯的封裝. 經過組件封裝業務邏輯, 並經過組件屬性(Props)向外暴露組件的配置字段. 採用頁面組件化, 複雜的頁面可視化搭建能夠轉化爲2個較簡單的操做:

  • 組件樹組合, 頁面可視化搭建變成頁面組件的可視化組合.
  • 組件配置編輯, 將對頁面內容的編輯轉化爲對組件的配置屬性(props)修改.

頁面前端框架

頁面組件化需依靠前端框架來實現. 頁面可視化搭建工具的架構方式對頁面前端框架有限制: 需選擇頁面可視化搭建工具支持的前端框架. 如: 頁面可視化搭建工具只支持基於 vue 的頁面, 那頁面組件化的前端框架只能選擇 vue.

可是前端技術團隊選用的前端框架, 通常已用於支持現有業務, 並沉澱了必定數量的技術組件和業務組件. 若是須要針對頁面可視化搭建工具進行前端框架的切換, 成本將會很大.

因此理想的頁面可視化搭建工具, 應該和頁面的前端框架解偶, 以下圖所示. 技術團隊在某前端框架中沉澱的技術組件和業務組件, 可在頁面可視化搭建工具的頁面中複用.

image

技術難點1:頁面可視化搭建工具與頁面前端框架解偶.

固然, 前端業務已選用了某前端框架, 開發專門支持該前端框架的頁面可視化搭建工具, 也是高效實現目標的選擇.

頁面模板

頁面模板包含完整的業務邏輯, 有助於快速生成業務頁面. 不一樣的頁面模板適用於不一樣的業務功能, 從模板庫中選擇合適的頁面模板並派生出默認業務頁面, 再對默認頁面進行可視化編輯, 從而生成目標業務頁面.

image

雲鳳蝶的頁面模板列表:

image
圖片來源: www.yunfengdie.com/

模板帶有頁面的默認數據; 對於組件化的頁面, 模板是從組件庫中選取部分組件, 並帶有各個組件的默認配置數據.

image

如上圖所示, 頁面組件庫中有組件A, 組件B, 組件C, 組件D, ..., 組件X等. 頁面模板一由組件庫中的組件A, 組件B和組件C組成, 實現了一個完整的業務功能; 頁面模板二由組件庫中的組件A, 組件B和組件X組成, 完成另外一個完整的業務功能.

頁面編輯

頁面由頁面組件組合而成, 頁面的編輯實際上是對頁面組件進行從新組合, 並編輯各頁面組件的內容. 頁面編輯包含2個部分: 編輯頁面組件和編輯頁面內容.

編輯頁面組件

組件樹

使用組件化的方式來組織頁面, 頁面能夠認爲是一棵組件樹, 以下圖所示, 樹中的節點爲頁面組件, 頁面組件能夠包含子組件.

image

在代碼編寫上, 經過組件標籤的組合來聲明一棵組件樹, 並在打包時生成頁面資源, 在運行時加載頁面資源渲染出頁面.

react 和 vue 的組件樹聲明示例:

image

編輯頁面組件的一個可行方式是: 動態地給頁面源碼添加組件, 而後從新打包生成頁面. 如經過可視化的方式替換 Left組件NewLeft組件 後, 對源碼的組件樹聲明作替換, 將 Left 標籤替換爲 NewLeft 標籤.

image

image

動態組件

一些前端框架支持動態組件, 能夠根據組件樹聲明動態渲染出組件, 而無需在構建前就定義好頁面的組件樹結構. 對動態組件頁面實現可視化組件編輯時, 能夠只編輯組件樹聲明文件, 而後將組件樹聲明傳入提早打包好的頁面中進行渲染. 採用動態組件能夠避免從新打包的耗時, 快速生成新頁面.

Vue 根據組件樹聲明動態地渲染組件示例以下圖, vue 動態組件使用 compontent 關鍵字來聲明, 並經過 is 屬性來決定實例化的具體組件. 對於 react, 組件是一個 js 對象, 直接在 jsx 中按照組件名稱返回對應組件就能夠了.

image

編輯頁面內容

組件化頁面的頁面內容編輯, 是對頁面中各個組件的組件屬性(Props)進行配置.

組件配置數據

一個組件包含組件屬性(Props), 組件狀態(State), 組件HTML模板(Template), 組件業務邏輯(Javascript), 組件樣式佈局(Style)等幾個部分.

組件的配置數據經過組件暴露的 Props 注入到組件中, 在組件內部 Props 做爲常量分發給 State, Template, Javascript, Style 等其餘組件內容, 由組件內容渲染出視圖.

image

組件差別化

組件是業務內容的呈現載體, 不一樣的業務內容, 封裝在不一樣的業務組件中. 因此頁面模板中的組件是差別化的, 差別點體如今組件的 Props, State, Template, Javascript, Style 等組件內容上. 在編輯不一樣組件內容時, 組件配置數據的數據結構是也是差別化的.

以下圖示的頁面包含3個組件: 頭部組件, 間隔區組件和天氣組件. 頭部組件的配置數據爲頭部標題和頭部圖片等; 間隔去組件的配置數據爲間隔提示文本等; 天氣組件的配置數據爲城市名稱. 不一樣的組件須要不一樣的配置數據.

image

須要爲各組件差別化的配置數據定義數據結構和字段類型, 理想的配置數據格式爲 JSON, 由於其格式靈活, 支持數據嵌套, 且前端友好.

組件配置表單

頁面可視化搭建工具的主要使用人員是運營/產品, 若是讓運營/產品人員直接編輯文本格式的組件配置數據, 操做不友好而且容易出錯. 需提供可視化的編輯方式 -- 使用 Form 表單來填入配置數據. Form 表單是頁面中數據交互的基本形式, 非開發人員使用也沒有技術門檻. 使用配置表單來填入配置數據有2個好處:

  • 配置表單交互功能完善, 容易使用.
  • 配置表單能夠添加校驗邏輯, 避免填入錯誤的配置數據.

image

如上圖所示, 因爲組件配置數據的差別化, 組件配置表單也是差別化的, 需爲組件庫中的每一個組件提供相應的配置表單. 若是爲每一個組件都編寫一個表單頁面, 工做量較大; 對於複雜的配置項, 表單頁面的編寫工做量可能會大於頁面組件的開發工做量. 須要重點考慮提供配置表單的方式.

技術難點2: 如何用最簡單的方式生成配置數據編輯表單.

組件層級關係

組件樹定義了組件間父子兄弟的層級關係, 父子組件經過數據流和事件進行關聯: 數據從父組件的 State 傳遞到子組件的 Props; 子組件的變動觸發 Event 通知父組件.

image

層級關係對數據流和佈局的影響

頁面可視化搭建工具編輯組件樹時, 會修改組件數據流. 而不一樣組件的 Props 和 State 是異構的, 在編輯組件樹時, 須要處理不一樣組件產生層級關係後對數據流的影響. 以下圖, 父組件的 State 只包含子組件A的 Props, 將子組件B掛載爲父組件的子組件, 父組件沒有子組件B的 Props, 會致使沒法渲染子組件B.

image

同理, 不一樣的組件有不一樣的樣式佈局, 編輯組件樹時, 須要處理不一樣組件產生層級關係後帶來的佈局影響.

image
圖片來源: alligator.io/react/using…

以下圖, 一個父組件爲行內組件, 給其添加一個塊級組件做爲子組件, 渲染後可能會致使行內組件被塊級組件撐開.

image

因此設計頁面可視化搭建工具的組件樹編輯功能時, 須要重點關注組件樹的層級關係, 解決組件間數據依賴和組件間佈局適配問題. 頁面可視化搭建工具須要制訂組件嵌套的規則和約束, 經過組件嵌套規則來確保可視化編輯後的組件樹正常渲染.

技術難點3: 如何組織頁面組件的層級關係.

使用組件嵌套的搭建工具示例:

image
圖片來源: github.com/jaweii/Vue-…

不嵌套的前端框架組件

能夠想象, 組件的嵌套會加大頁面可視化搭建工具的架構設計和開發難度.

咱們注意到, 營銷活動的主要平臺是移動端, 移動端頁面的經常使用的佈局策略是: 寬度鋪滿, 高度滾動. 若是前端框架組件都設置爲鋪滿寬度, 頁面展現時組件只需在瀏覽器垂直方向上順序排列, 則組件組合時不須要嵌套 -- 全部組件互爲兄弟節點.

這種鋪滿頁面寬度的組件, 很是適合搭建移動端頁面的場景: 在承載頁面邏輯的同時, 使得頁面的編輯更加簡單, 使用者只需處理組件的順序, 無需處理組件的嵌套.

在移動端, 使用非嵌套組件層級規則的頁面可視化搭建工具備: 阿里雲鳳蝶pipeline 等.

阿里雲鳳蝶圖示:

image

可視化搭建PC端中後臺系統頁面的工具, 一樣能夠採用不嵌套組件層級規則, 如阿里的飛冰:

image

頁面預覽

頁面實時預覽是頁面可視化搭建工具的必要部分, 使用人員能夠在經過頁面預覽來查看和驗證可視化編輯的效果.

頁面預覽示例:

image

用戶的可視化編輯包括修改組件樹和修改組件配置數據. 以下圖, 用戶修改頁面後, 須要從新渲染頁面組件, 獲得新的預覽頁面.

image

實現頁面預覽有兩種方式: 頁面掛載後臺渲染.

頁面掛載

頁面掛載指在編輯器前端頁面的某個元素節點(div)上渲染出用戶編輯的效果. 頁面掛載流程圖以下:

image

使用頁面掛載的預覽方式, 編輯器前端頁面須要提供組件庫組件渲染環境(組件庫前端框架); 爲實現前端渲染, 編輯器前端源碼需引入組件庫組件源碼, 後續組件庫更新, 編輯器須要同步更新. 頁面掛載方式有如下特色:

  • 實現頁面預覽技術方案可行, 實時渲染速度快.
  • 爲實現渲染, 編輯器的技術選型需和組件庫前端框架一致.
  • 編輯器源碼和組件庫源碼耦合.
  • 組件庫組件渲染後的代碼邏輯和樣式佈局, 可能會污染編輯器頁面.

後臺渲染

後臺渲染指在後臺進行用戶編輯結果頁面的渲染和生成, 編輯器前端頁面經過 iframe 加載和展現結果頁面. 後臺渲染流程圖以下:

image

使用後臺渲染的預覽方式, 編輯器前端頁面並不須要渲染組件庫的組件; 甚至不須要組件源碼, 只需知道各個組件的描述信息. 後臺渲染有如下特色:

  • 能夠實現編輯器和組件庫前端框架的分離.
  • 能夠實現編輯器和組件庫各組件的分離.
  • 能夠避免預覽頁面的邏輯和樣式污染編輯器環境.
  • 要求後臺和組件庫提供頁面後臺渲染能力, 並要求後臺渲染速度快, 用戶須要"實時"預覽.

難點4: 如何實現組件庫的快速後臺渲染, 從而實現編輯器和組件庫前端框架的分離.

頁面構建

頁面構建是組件化前端源碼生成頁面資源的必要環節: 在開發時須要進行開發構建來進行頁面調試; 在可視化編輯後可能須要從新構建來生成預覽頁面; 在發佈前須要進行生產構建.

在可視化搭建頁面時須要「實時」預覽, 要求頁面頁面構建效率高, 實現快速的構建和打包. 更進一步, 後臺渲染其實和服務端渲染很像, 可否借鑑服務端渲染的技術思路.

自定義模板和組件開發

頁面可視化搭建工具在業務中的落地, 須要根據不一樣的業務場景進行業務組件和頁面模板的自定義開發. 這對頁面可視化搭建工具提出3個要求:

  • 頁面可視化搭建工具要支持業務現有的前端框架.

    避免後續組件和模板自定義開發時的工做量和割裂感. 咱們是但願複用現有前端框架組件, 而不是用另外一個前端框架重寫一遍.

  • 組件和模板的編寫方式需遵循較簡單的編寫約定, 避免開發人員難上手和寫起來不舒服.

  • 自定義模板和組件和在開發模式下進行調試和測試.

    頁面可視化搭建工具必然會對頁面模板和頁面組件的編碼方式進行限定. 這要求就頁面可視化工具在頁面模板和頁面組件上的約束較少, 減小對前端框架代碼組織方式的入侵點.

理想的活動頁面可視化搭建工具

頁面可視化搭建工具, 須要對頁面作一些約定和約束, 在可視化搭建時遵循工具約定和約束來編輯頁面. 從頁面可視化搭建工具的技術要點中, 能夠概括出活動頁面可視化搭建工具的理想形態.

頁面可視化搭建工具備不一樣的框架設計和實現方式, 不一樣的功能有不一樣的適用場景, 詳細分類能夠參考筆者之前的文章: 頁面可視化搭建工具前生今世.

概述

運營頁面搭建工具, 實現基於模板的頁面生成; 將頁面的邏輯功能封裝在組件內, 聲明頁面配置數據並提供配置表單, 經過對配置表單的數據填充, 進行少許頁面編輯就能夠完成業務頁面搭建.

image

不嵌套的組件

在編輯自由度的選擇上, 選用不嵌套的組件.各組件鋪滿頁面寬度, 在頁面高度方向順序排列.解決組件嵌套帶來的數據流問題. 不嵌套的組件以下圖各個紅框框起來的部分所示.

image

配置表單自動生成

配置表單的做用是生成和約束 JSON 配置數據, 業界已有對 JSON 進行描述和自動生成表單的方案 -- JSON Schema. 按照 JSON Schema 規範對 JSON 數據進行描述, 能夠動態渲染出配置表單; 且 JSON Schema 能夠對編輯後的數據作格式校驗, 避免編輯錯誤. 這比編寫一個表單頁面更加簡單和高效.

image
圖片來源: github.com/json-editor…

JSON Schema 的語法並非很精簡, 雲鳳蝶的 Schema 語法 等方案更簡潔, 可是雲鳳蝶的語法沒有開源的表單生成庫支持, 在開源實踐上仍是 JSON Schema 最佳.

理想活動頁面搭建工具特色

  • 採用組件化和頁面模板實現頁面生成效率的提高.
  • 採用不嵌套的組件層級簡化數據流和樣式佈局.
  • 採用 JSON Schema 聲明配置數據, 自動生成配置表單.
  • 採用後臺渲染, 使編輯系統與組件前端框架解耦.
  • 在遵循編輯系統約定下, 組件能夠自由拓展, 前端框架能夠自由選擇.

頁面可視化搭建框架 Pipeline

簡介

Pipeline 是一個開源的頁面可視化搭建框架, 主要由筆者在維護. Pipeline 意爲流水線, 指望 pipeline 像工廠流水線同樣能夠高效地組裝活動頁面.

所謂框架, 是它實現了頁面可視化搭建的基本功能, 解決了頁面可視化搭建的基本難點, 可讓開發者快速擁有頁面搭建的能力, 並支持私有部署和二次開發.

項目信息:

功能 Demo

可視化編輯

demo

如動圖所示, pipeline 的可視化編輯能力有:

  • 可視化修改頁面全局配置, 如修改頁面主題顏色.
  • 可視化修改頁面組件內容, 如修改組件的圖片和替換組件文本.
  • 實時預覽頁面編輯效果, 即刻得到搭建後的頁面.
  • 頁面支持用戶交互.

組件編輯

dnd_demo

如動圖所示, pipeline 的組件編輯能力有:

  • 動態增刪頁面組件.
  • 可視化的組件拖拽, 拖拽組件庫組件插入到頁面組件列表中.
  • 組件能夠包含業務邏輯(網絡請求和用戶交互).

支持的前端框架

Pipeline 實現了編輯器和頁面前端框架的分離, 能夠支持不一樣的前端框架. 所謂支持的前端框架, 就是對某個前端框架按照 pipeline 的約束規則進行組件編輯方式和工程構建方式的改造, 使得前端框架頁面能夠在 pipeline 中可視化搭建.

目前已經支持 Vue, React, 和 Omi, 理論上能夠支持任意前端框架.

image

框架特色

  • 開源頁面可視化搭建框架.
  • 自定義頁面可配置字段.
  • 組件動態增減, 組件拖拽.
  • 從頁面模板快速生成業務頁面.
  • 模板工程/編輯器/後臺服務解偶.
  • 模板工程前端框架無關: 支持 vue 和 react 等.
  • 支持自由拓展頁面組件, 不限制組件樣式佈局, 接口調用等.
  • 前端工程約束少, 不限制使用其餘技術(Redux, SSR, UI庫等).

與雲鳳蝶的對比

阿里雲鳳蝶 是目前市場上可見中最棒的頁面可視化搭建服務, pipeline 的不少方面和雲鳳蝶類似, 作個簡單對比:

雲鳳蝶 pipeline
商業化解決方案, 直接可用 開源系統, 基礎的頁面搭建框架, 須要自行部署
生成的頁面, 上傳的圖片等只能託管在阿里, 也限定域名 資源落地和周邊功能須要自行搭建, 可是能夠100%掌控全部資源
配置表單功能比較完善 配置表單比較基礎, 須要提高
使用自定義的組件配置約束規則 使用通用的 JSON Schema 規範
模板前端框架採用 Nunjucks 前端框架採用沒有約束, 已經支持 vue 和 react 等, 業務遷移成本低
隱藏了模板的構建處理過程, 提供製定的 IDE 採用 webpack 構建, 模板開發與正常前端項目開發一致
不支持自定義頁面級別的配置項 支持自定義頁面級別的配置項

總的來講: 雲鳳蝶是完整的商業化頁面可視化搭建系統, 適合偏業務運營的公司; pipeline 是開源的頁面可視化搭建框架, 適合須要自建頁面可視化搭建系統且有技術人員支持的公司.

下一步工做

  • 完善技術實現文檔, 使用文檔, 系統部署文檔和模板開發文檔.
  • 提供對更多前端框架的支持.
  • 提供更加豐富的可視化交互方式.

總結

本文討論了活動頁面開發的痛點, 總結出頁可視化搭建工具的7個技術要點和4個技術難點, 並整理出理想的運營頁面可視化搭建工具, 最後介紹頁面可視化搭建框架 pipeline.

行文倉促, 對頁面可視化搭建話題或開源項目 pipeline 感興趣, 歡迎討論.

References

  • pipeline

github.com/page-pipepl…

  • 頁面可視化搭建工具前生今世

github.com/CntChen/cnt… /15

  • Vue 2.0學習筆記:組件數據傳遞

www.w3cplus.com/vue/compone…

  • 阿里雲鳳蝶

i.yunfengdie.com/

EOF

相關文章
相關標籤/搜索