Semantic-UI的React實現(二):CSS類構造模塊


更簡單的類名標簽

Semantic-UI使用了更簡單的類名聲明。用過Bootstrap的同學都會被其復雜的類名標簽折磨過,例如一個簡單的按鍵樣式,不論顏色或是大小,都需要btn-前綴聲明:

 
  1. <button?type="button"?class="btn?btn-primary?btn-lg?active">Primary?button</button>?

在Semantic-UI中,類名更接近自然表述:

 
  1. <button?class="ui?blue?large?active?button">Blue?Button</button>?

語義化的樣式聲明

樣式名并不是對某種組件進行的類型聲明,可以通用到其他組件中。例如對于Label(標簽)組件,也可用與button相同的CSS類聲明其樣式:

 
  1. <div?class="ui?blue?large?active?label">Blue?Label</div>?

這樣的好處是顯而易見的,CSS類名語義化,剛方便使用和學習。

類名構造模塊的實現

從以上細節可以看出,每個組件的類聲明均可由公用模塊生成,每個組件僅僅聲明本模塊可使用的Props即可。以Button舉例如下:

 
  1. import?PropHelper?from?'./PropHelper';?
  2. import?UiElement?from?'./UiElement';?
  3. ...?
  4. ?
  5. let?PROP_TYPES?=?['primary',?'size',?'color',?'basic',?'active',?...];?
  6. ?
  7. class?Button?extends?UiElement?{?
  8. ?????
  9. ????static?propTypes?=?{?
  10. ????????...PropHelper.createPropTypes(PROP_TYPES)?
  11. ????};?
  12. ?????
  13. ????render()?{?
  14. ?????????
  15. ????????let?style?=?this.createElementStyle(this.props,?PROP_TYPES,?'button');?
  16. ?????????
  17. ????????return?(?
  18. ????????????<div?id={this.props.id}?className={style}?tabIndex='0'>?
  19. ????????????????{this.props.children}?
  20. ????????????</div>?
  21. ????????);?
  22. ????}?
  23. ?????
  24. ????...?
  25. }??

Button類聲明了其可以使用的class類名,通過共通處理生成style即可。生成style的共同處理,由PropsHelper類負責完成。

PropsHelper

PropsHelper類主要的職責有兩個:

  1. 生成各組件所需的class類集合
  2. 生成各組件的props屬性檢查定義

PropsHelper作為工具類,相關處理過程中并無狀態參與,方法應該聲明為靜態方法(static)。

props屬性檢查

Semantci-UI中的所有class類屬性的集合是可枚舉的,這些屬性直接在PropsHelper中定義即可:

 
  1. const?BOOL_PROPS?=?['ui',?'active',?'disabled',?'circular',?...];?
  2. const?STRING_PROPS?=?['icon',?'appendClass',?...],?
  3. const?NUMBER_PROPS?=?['column',?'wide',?...],?
  4. const?COLLECTION_PROPS?=?['color',?'size',?'position',?...];??

對于每個組件的屬性檢查定義,可以遍歷傳入的屬性,并根據名字找到該屬性的PropTypes定義。

 
  1. class?PropsHelper?{?
  2. ?????
  3. ????...?
  4. ?????
  5. ????/**?
  6. ?????*?生成屬性檢查?
  7. ?????*/?
  8. ????static?createPropTypes(propTypes)?{?
  9. ?????????
  10. ????????let?result?=?{};?
  11. ????????propTypes.forEach(function(typeName,?index)?{?
  12. ?????
  13. ????????????if?(BOOL_PROPS.indexOf(typeName)?>=?0)?{?
  14. ??????????????result[typeName]?=?React.PropTypes.bool;?
  15. ????????????}?
  16. ????????????else?if?(STRING_PROPS.indexOf(typeName)?>=?0)?{?
  17. ??????????????result[typeName]?=?React.PropTypes.string;?
  18. ????????????}?
  19. ????????????else?if?(NUMBER_PROPS.indexOf(typeName)?>=?0)?{?
  20. ??????????????result[typeName]?=?React.PropTypes.number;?
  21. ????????????}?
  22. ????????????else?if?(COLLECTION_PROPS.indexOf(typeName)?>=?0)?{?
  23. ??????????????result[typeName]?=?React.PropTypes.oneOf(PROPS_VALUES[typeName]);?
  24. ????????????}?
  25. ????????});?
  26. ?????????
  27. ????????return?result;?
  28. ????}?
  29. }??

class類集合組裝

與createPropTypes同樣的思路,將傳入的組件props遍歷一遍,找到各自prop屬性的類型定義,根據類型定義編輯和組裝該組件的class類集合。

 
  1. class?PropsHelper?{?
  2. ?
  3. ????...?
  4. ?????
  5. ????/**?
  6. ?????*?根據屬性生成引用的class?
  7. ?????*/?
  8. ????static?createStyle(props,?types)?{?
  9. ?
  10. ????let?style?=?'';?
  11. ????for?(let?i?=?0;?i?<?types.length;?i++)?{?
  12. ??????let?type?=?types[i];?
  13. ??????if?(props.hasOwnProperty(type))?{?
  14. ????????style?+=?this.formatStyleValue(props[type],?type);?
  15. ??????}?
  16. ????}?
  17. ?
  18. ????return?style;?
  19. ??}?
  20. ???
  21. ??/**?
  22. ???*?格式化屬性對應的class?
  23. ???*/?
  24. ??static?formatStyleValue(value,?type)?{?
  25. ?
  26. ????//?如果是數字型屬性?
  27. ????if?(NUMBER_PROPS.indexOf(type)?>=?0)?{?
  28. ??????return?'?'?+?this.getNumberStr(value)?+?'?'?+?type;?
  29. ????}?
  30. ????else?if?(COLLECTION_PROPS.indexOf(type)?>=?0)?{?
  31. ??????if?(type?==?'size')?return?'?'?+?value;?
  32. ??????return?'?'?+?value?+?'?'?+?type;?
  33. ????}?
  34. ????else?if?(BOOL_PROPS.indexOf(type)?>=?0)?{?
  35. ?
  36. ??????if?(!value)?return?'';?
  37. ?
  38. ??????if?(type?==?'imaged')?return?'?image';?
  39. ??????if?(type?==?'iconed')?return?'?icon';?
  40. ??????if?(type?==?'long')?return?'?long?scrolling';?
  41. ??????if?(type?==?'equalWidth')?return?'';?
  42. ??????return?'?'?+?type;?
  43. ????}?
  44. ????else?if?(STRING_PROPS.indexOf(type)?>=?0)?{?
  45. ??????return?'?'?+?value;?
  46. ????}?
  47. ????else?{?
  48. ??????return?'';?
  49. ????}?
  50. ??}?
  51. }??

這樣實現以后,各組件在各自屬性的定義和class類聲明的處理時獲得了兩方面的益處:

  1. 屬性統一管理,不用再各自聲明
  2. 代碼復用性和耦合性更佳(特別是在復雜組件的使用中)
作者:sheva
來源:51CTO

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/281053.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/281053.shtml
英文地址,請注明出處:http://en.pswp.cn/news/281053.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

skype自動回復_如何在Windows 10上阻止Skype自動啟動

skype自動回復Microsoft微軟The Skype app included with Windows 10 now has a notification area icon. That’s great, but what if you never use Skype and don’t want it starting every time you sign in? Here’s how to get rid of it. Windows 10隨附的Skype應用程…

Vue 組件實例屬性的使用

前言 因為最近面試了二、三十個人&#xff0c;發現大部分都還是只是停留在 Vue 文檔的教程。有部分連教程這部分的文檔也沒看全。所以稍微寫一點&#xff0c;讓新上手的 Vuer 多了解 Vue 文檔的其他更需要關注的點。 因為 Vue 文檔已經是個很成熟的文檔&#xff0c;并且實現的 …

C# 讀取硬盤信息類

在編寫工具檢查硬盤信息時&#xff0c;總結常用到的類&#xff1a; Win32_DiskDrive 這個用了檢查整個硬盤的信息&#xff0c;如果電腦只有一個硬盤&#xff0c;那只顯示一條信息。參考如下代碼&#xff0c;AddTextBox為自定義顯示函數。&#xff08;MSDN class 查詢&#xff1…

95后滬漂女孩深陷“狠”且“卷”職場,向上思維,永不過時!

hi&#xff0c;這里是桑小榆。最近和一個伙伴oncall了很久&#xff0c;對我的文章以及思想轉變產生了很大的共鳴&#xff0c;她向我分享了一些職場經歷還有成長經歷等&#xff0c;她的這些經歷也讓我引發了一定的思考。光光&#xff0c;最近剛升任了部門主管&#xff0c;對于當…

PHP:6種GET和POST請求發送方法

在i94web博客中&#xff0c;我試過了暢言和多說兩種社會化評論框&#xff0c;后來還是拋棄了暢言&#xff0c;不安全。 無論是暢言還是多說&#xff0c;我都需要從遠程抓取文章的評論數&#xff0c;然后存入本地數據庫。對于多說&#xff0c;請求的格式如下&#xff1a; // 獲取…

解決Ubuntu 16.04下提示boot分區空間不足的辦法

原文地址: http://www.jb51.net/article/106976.htm   https://www.linuxidc.com/Linux/2015-09/123227.htm 因為linux內核一直在更新&#xff0c;更新后&#xff0c;舊的內核就不在使用&#xff0c;但舊的內核文件還在boot里面&#xff0c;占據著空間&#xff0c;更新幾次過…

3d鏡頭 適配_您是否應該將鏡頭適配器與無反光鏡相機一起使用?

3d鏡頭 適配Canon佳能Mirrorless cameras aren’t the future, they’re the present. If you’re switching from an older DSLR, though, the obvious thing to do is just buy an adapter so you can keep using your old gear. 無反光鏡相機不是未來&#xff0c;而是現在。…

C#彈窗提示并自動關閉方法

剛學C#不久&#xff0c;就寫個工具&#xff0c;總結寫一個簡便自定義提示窗口方法&#xff0c;并自動關閉。 1.在項目添加windows form&#xff08;非user control&#xff09;&#xff0c;命名為Form_wait。 2.在Form_wait,加入需要控件與一個定時器timer1。 數字10為計時顯…

dotNET 7:最小 API 使用

最小 API 并不是在 .NET 7 中才加入的&#xff0c;記得應該是在 .NET 6 中就已經提供&#xff0c;只是對我來說&#xff0c;到現在才開始使用。創建一個最小 API在 VS 2022 中創建 WebAPI 項目&#xff0c;不勾選使用控制器&#xff0c;創建出來的就是最小 API &#xff1a;不勾…

Taro小程序采坑記

Taro&#xff0c;京東凹凸實驗室出品的適配多端的一個框架&#xff0c; Taro 是一套遵循 React 語法規范的 多端開發 解決方案。現如今市面上端的形態多種多樣&#xff0c;Web、React-Native、微信小程序等各種端大行其道&#xff0c;當業務要求同時在不同的端都要求有所表現的…

struts入門

struts工作過程&#xff1a; 反射代碼&#xff1a; Class clazz Class.forName("action全路徑"); Method m clazz.getMethod("execute"); Object o m.invoke(); package標簽&#xff1a; 轉發&#xff1a;地址欄不變 修改struts默認常量值&#xff1a; 常…

《Android應用開發攻略》——2.14 備份Android應用程序數據

2.14 備份Android應用程序數據 Pratik Rupwal2.14.1 問題當用戶恢復出廠設置或者改用新的Android設備時&#xff0c;應用程序丟失存儲數據或者應用程序設置。2.14.2 解決方案Android的Backup Manager&#xff08;備份管理器&#xff09;能夠在應用程序重新安裝時自動恢復備份數…

C#程序開機啟動與獲取程序啟動路徑

寫windows工具時&#xff0c;要進行電源管理&#xff0c;需要重啟與開關機OS&#xff0c;這樣工具就需要自動啟動。查了網上很多資料&#xff0c;修改注冊列表就可以。 但是&#xff0c;復制幾個網站的代碼并自己修改都發現不行&#xff0c;最后發現腳本之家這段代碼才成功&am…

wpf office 菜單_如何帶回Office 2007中的舊菜單

wpf office 菜單Using the new Ribbon feature in Office 2007 takes time to learn…time you don’t have because projects are stacking up. Today we will look at UBitMenu, a utility that puts the familiar Office 2003 menu into the 2007 ribbon. 使用Office 2007中…

Swagger UI 僅為用戶暴露已授權終結點

前言當需要在生產環境中提供 Swagger UI 時&#xff0c;我們可以通過身份驗證&#xff0c;控制只有授權用戶才能訪問 Swagger UI 頁面。但是我們希望更進一步&#xff0c;每個用戶只能看到授權給他的終結點&#xff0c;而不會暴露其他未授權終結點信息。比如&#xff0c; API 提…

php實現約瑟夫環

function king($high,$size){ $monkey range(1, $high); $i 0 ; while (count($monkey)>1) { $i; $head array_shift($monkey); if(($i % $size) ! 0){ array_push($monkey,$head); } } return $monkey[0];} var_dump(king(10,3));轉載于:https://www.cnblogs.com/lijint…

微軟正式發布Azure Storage上的靜態網站

微軟正式宣布了Azure Storage上的靜態網站&#xff0c;提供了從托管在Azure Storage上的HTML、CSS和JavaScript文件提供內容的能力。靜態網站包含內容固定的Web頁面&#xff0c;同時仍然允許利用JavaScript等客戶端代碼來創建豐富的用戶體驗。 有了這個新功能&#xff0c;繼用于…

帝國國王科技大學上機題解(二)

1.找到字符串中出現次數最少的字符 題目描寫敘述 給定一個字符串&#xff08;長度小于50&#xff09; 找到該字符串出現次數最少的字符 假設有兩個字符出現次數同樣&#xff0c;并且均出現最少。那么ASCII碼小的字符優先 輸入 輸入為一行字符串。不含空格 輸出 輸出出現次數最少…

如何在計算機上閱讀漫畫書

Reading and organizing a comic book collection on your computer is efficient and a lot of fun. Today we will look at a couple of free applications that allow you to read your favorite comic books on your computer. 在計算機上閱讀和組織漫畫集非常有效&#xf…

C# WinForm 自啟動/模擬開機自動啟動

遇到重寫啟動步驟&#xff0c;C#調試時顯得比較折騰&#xff0c;既要等待重啟&#xff0c;又要保存當前文件。 讓程序自動重啟模擬這樣電腦重啟步驟&#xff0c;顯得非常方便。在http://bbs.csdn.net/topics/100187453找到下面代碼&#xff0c;直接使用。 ProcessStartInfo p…