摘要:前言目前流行的前端組件庫都支持移動設備優先的響應式布局特性。充分利用了的優良特性,充分發揮其最大價值。不重復造輪子,而是采用業界最新的開源技術,進行全棧開發的最佳組合。
前言
目前流行的前端UI組件庫都支持移動設備優先的響應式布局特性。但基于Mobile和PC兩個場景的不同用戶體驗,也往往會實現Mobile和PC兩個版本。
PC場景下的Web工程,如大量的后臺前端管理模版,雖然支持Mobile自適應,但其用戶體驗差強人意。
Cabloy采用不同的思路,仍然基于移動優先,同時通過特殊的布局優化,使得移動頁面可以完整的用于PC場景,既保證了用戶體驗,又提升了開發效率,大大簡化了開發工作量。
PC:https://admin.cabloy.com
Mobile:
上圖 Mobile布局 PC布局 進一步分析Cabloy的PC布局將頁面切分為若干個Mobile+Pad的組合,帶來了與眾不同的用戶體驗。
從此開發類似于微信公眾號或H5混合開發的項目,再也不用建立兩套獨立的工程。
Cabloy前端基于Framework7,并一直跟進其最近的開發進度,從1.0到2.0,再到3.0。Cabloy充分利用了Framework7的優良特性,充分發揮其最大價值。
Cabloy的作者zhennann在Framework7的貢獻圖如下:
Framework7將頁面分為若干個View,每個View對應一個Router,管理若干個Page,從而非常方便的實現Page之間的堆疊。
Cabloy的PC布局,將頁面分為若干個Tab,每個Tab再包含若干個View。通過對Router的patch,實現Tab之間與View之間的URL跳轉。
Cabloy通過不同的模塊封裝不同布局的實現邏輯,然后在根結點組件中針對頁面的尺寸的變化渲染不同的布局。
需要特別說明的是,Cabloy中的模塊是一個相對獨立的實體,可以根據需要異步加載,提升頁面加載性能。
egg-born-front/src/base/mixin/config.js:
config.js配置布局信息,可通過修改配置實現自己的布局管理邏輯
// config const config = { modules: {}, layout: { breakpoint: 800, items: { mobile: { module: "a-layoutmobile", component: "layout", }, pc: { module: "a-layoutpc", component: "layout", }, }, }, };
egg-born-front/src/inject/pages/app.vue:
app.vue是根結點組件,動態異步加載所需的布局組件
Mobile布局組件源碼參見:https://github.com/zhennann/egg-born-module-a-layoutmobile/blob/master/front/src/components/layout.vue
a-layoutmobile/front/src/config/config.js:
config.js可以靈活配置布局的顯示元素
export default { layout: { login: "/a/login/login", loginOnStart: true, toolbar: { tabbar: true, labels: true, bottomMd: true, }, tabs: [ { name: "Home", tabLinkActive: true, iconMaterial: "home", url: "/a/base/menu/list" }, { name: "Atom", tabLinkActive: false, iconMaterial: "group_work", url: "/a/base/atom/list" }, { name: "Mine", tabLinkActive: false, iconMaterial: "person", url: "/a/user/user/mine" }, ], }, };PC布局組件
Mobile布局組件源碼參見:https://github.com/zhennann/egg-born-module-a-layoutpc/blob/master/front/src/components/layout.vue
a-layoutpc/front/src/config/config.js:
config.js可以靈活配置布局的顯示元素
export default { layout: { login: "/a/login/login", loginOnStart: true, header: { buttons: [ { name: "Home", iconMaterial: "dashboard", url: "/a/base/menu/list", target: "_dashboard" }, { name: "Atom", iconMaterial: "group_work", url: "/a/base/atom/list" }, ], mine: { name: "Mine", iconMaterial: "person", url: "/a/user/user/mine" }, }, size: { small: 320, top: 60, spacing: 10, }, }, };結語
Cabloy是采用Javascript進行全棧開發的最佳實踐。
Cabloy不重復造輪子,而是采用業界最新的開源技術,進行全棧開發的最佳組合。
歡迎大家拍磚、踩踏。
地址:https://github.com/zhennann/cabloy
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/96794.html
摘要:文檔官網文檔演示是什么是一款頂級全棧開發框架。不重復造輪子,而是采用業界最新的開源技術,進行全棧開發的最佳組合。漸進式開發由于模塊的高度內聚,可以將業務以模塊的形式沉淀,在多個項目中重復使用,既可貢獻到開源社區,也可部署到公司內部私有倉庫。 文檔 官網 && 文檔 演示 PC:https://admin.cabloy.com Mobile: showImg(https://seg...
摘要:文章也不例外,只有提交進入正常狀態,才會進行渲染。提交并預覽首頁文章頁部署實例與子域名支持多實例,實例與網站子域名一一對應,不同實例的數據完全隔離。 介紹 Cabloy-CMS是什么 Cabloy-CMS是基于CabloyJS全棧業務開發框架開發的動靜結合的CMS,可以快速構建企業網站、博客、社區、商城等Web應用。 在線演示 https://zhennann.com 特性 Cablo...
摘要:然而這也意味著成為一個全棧工程師,比以往的任何一個時間要容易得多。所以,我們開始談論如何成為一名全棧增長工程師。再成為增長工程師整一個系列社區電子書全棧增長工程師指南電子書全棧增長工程師實戰算是我對的一個研究。 (文末有驚喜) 記得我們在《RePractise前端篇: 前端演進史》中提到技術在最近十幾年的飛速發展,當然最主要的就是:技術的復雜度不斷地從應用層抽象到了框架層。雖說: 技術...
閱讀 500·2021-09-03 00:22
閱讀 1375·2021-08-03 14:03
閱讀 2092·2021-07-25 21:37
閱讀 656·2019-08-30 13:18
閱讀 1884·2019-08-29 16:19
閱讀 2693·2019-08-29 13:22
閱讀 1303·2019-08-29 12:16
閱讀 2591·2019-08-26 12:16