Material UI:非常強大的CSS框架

2015-06-27    分類:CSS框架、Web應用開發、開源軟體、首頁精華4人評論發表於2015-06-27

本文由碼農網 – 小峰原創,轉載請看清文末的轉載要求,歡迎參與我們的付費投稿計劃

Material UI 是一款功能非常強大,介面卻十分清新簡潔的CSS框架,Material UI利用了Google的Material Design 全新設計語言,並且讓每一個UI元件都變得非常獨立,因此開發者使用Material UI也會比較簡單。和Bootstrap類似,Material UI提供了很多常用的UI元件,除了最基本的選單、按鈕、滑動杆、進度條、單選框/核取方塊外,它還提供了一個非常有趣的日曆元件,另外還提供了一些很有趣的圖示。

Material UI 的特點

  • 元件很豐富,每一個元件的風格比較一致。
  • 提供了 npm 包的形式,使用起來相對比較方便。
  • 這一切都是開源的,你可以任意使用這個開源的CSS框架。

Material UI 的應用例項

首先我們從最基本的看起。

選單

下面是一個簡單的多級下拉選單

程式碼如下:

nestedMenuItems = [
    { type: mui.MenuItem.Types.NESTED, text: 'Reports', items: [
      { payload: '1', text: 'Nested Item 1' },
      { type: mui.MenuItem.Types.NESTED, text: 'Nested Item 2', items: [
        { payload: '1', text: 'Nested Item 2.1' },
        { type: mui.MenuItem.Types.NESTED, text: 'Nested Item 2.2', items: [
          { payload: '1', text: 'Nested Item 2.2.1' },
          { payload: '3', text: 'Nested Item 2.2.2' }
        ] },
        { payload: '3', text: 'Nested Item 2.3' }
      ] },
      { payload: '3', text: 'Nested Item 3' },
      { type: mui.MenuItem.Types.NESTED, text: 'Nested Item 4', items: [
        { payload: '1', text: 'Nested Item 4.1' },
        { type: mui.MenuItem.Types.NESTED, text: 'Nested Item 4.2', items: [
          { payload: '1', text: 'Nested Item 4.2.1', disabled: true },
          { payload: '3', text: 'Nested Item 4.2.2' }
        ] },
        { payload: '3', text: 'Nested Item 4.3' }
      ] },
      { payload: '4', text: 'Nested Item 5' }
    ] },
    { payload: '1', text: 'Audio Library'},
    { payload: '2', text: 'Settings'},
    { payload: '3', text: 'Logout', disabled: true}
  ];

<Menu menuItems={nestedMenuItems} autoWidth={false}/>

下面是一個帶圖示的垂直選單

程式碼如下:

//iconClassName is the classname for our icon that will get passed into mui.FontIcon
iconMenuItems = [
   { payload: '1', text: 'Live Answer', iconClassName: 'muidocs-icon-communication-phone', number: '10' },
   { payload: '2', text: 'Voicemail', iconClassName: 'muidocs-icon-communication-voicemail',  number: '5' },
   { payload: '3', text: 'Starred', iconClassName: 'muidocs-icon-action-stars', number: '3' },
   { payload: '4', text: 'Shared', iconClassName: 'muidocs-icon-action-thumb-up',  number: '12' }
];

<Menu menuItems={iconMenuItems} autoWidth={false}/>

按鈕

下面是簡單的彩色按鈕,點選按鈕會出現波浪擴散的動畫效果。

程式碼如下:

//Raised Buttons
<RaisedButton label="Default" />
<RaisedButton label="Primary" primary={true} />
<RaisedButton label="Secondary" secondary={true} />
<div style={styles.container}>
  <RaisedButton primary={true} label="Choose an Image">
    <input type="file" style={styles.exampleImageInput}></input>
  </RaisedButton>
</div>
<div style={styles.container}>
  <RaisedButton linkButton={true} href="https://github.com/callemall/material-ui" secondary={true} label="Github">
    <FontIcon style={styles.exampleButtonIcon} className="muidocs-icon-custom-github"/>
  </RaisedButton>
</div>
<RaisedButton label="Disabled" disabled={true} />

美化單選框核取方塊

下面是Material UI經過美化過的單選框和核取方塊

程式碼如下:

<RadioButtonGroup name="shipSpeed" defaultSelected="not_light">
        <RadioButton
          value="light"
          label="prepare for light speed"
          style={{marginBottom:16}} />
        <RadioButton
          value="not_light"
          label="light speed too slow"
          style={{marginBottom:16}}/>
        <RadioButton
          value="ludicrous"
          label="go to ludicrous speed"
          style={{marginBottom:16}}
          disabled={true}/>
      </RadioButtonGroup>

日曆元件

這是個人覺得最漂亮的CSS日曆元件

程式碼如下:

//Portrait Dialog
<DatePicker
  hintText="Portrait Dialog"

//Landscape Dialog
<DatePicker
  hintText="Landscape Dialog"
  mode="landscape"/>

// Ranged Date Picker
<DatePicker
  hintText="Ranged Date Picker"
  autoOk={this.state.autoOk}
  minDate={this.state.minDate}
  maxDate={this.state.maxDate}
  showYearSelector={this.state.showYearSelector} />

Material UI還有很多有用的CSS UI元件,你可以前往其官方網站下載及學習使用。

本文連結:http://www.codeceo.com/article/material-ui.html
本文作者:碼農網 – 小峰
原創作品,轉載必須在正文中標註並保留原文連結和作者等資訊。]

相關文章