在vue中,Mint UI是餓了么團(tuán)隊(duì)開(kāi)源的一款基于Vue.js的移動(dòng)端組件庫(kù)。Mint UI包含豐富的CSS和JS組件,能夠滿足日常的移動(dòng)端開(kāi)發(fā)需要;通過(guò)它,可以快速構(gòu)建出風(fēng)格統(tǒng)一的頁(yè)面,提升開(kāi)發(fā)效率。
Mint UI是餓了么團(tuán)隊(duì)開(kāi)源的一款基于Vue.js 的移動(dòng)端組件庫(kù)。
官網(wǎng):https://mint-ui.github.io/#!/zh-cn
中文文檔 :http://mint-ui.github.io/docs/#/zh-cn2
特性介紹
-
Mint UI 包含豐富的 CSS 和 JS 組件,能夠滿足日常的移動(dòng)端開(kāi)發(fā)需要。通過(guò)它,可以快速構(gòu)建出風(fēng)格統(tǒng)一的頁(yè)面,提升開(kāi)發(fā)效率。
-
真正意義上的按需加載組件。可以只加載聲明過(guò)的組件及其樣式文件,無(wú)需再糾結(jié)文件體積過(guò)大。
-
考慮到移動(dòng)端的性能門(mén)檻,Mint UI 采用 CSS3 處理各種動(dòng)效,避免瀏覽器進(jìn)行不必要的重繪和重排,從而使用戶獲得流暢順滑的體驗(yàn)。
-
依托 Vue.js 高效的組件化方案,Mint UI 做到了輕量化。即使全部引入,壓縮后的文件體積也僅有 ~30kb (JS + CSS) gzip。
在 Vue-cli 中使用 Mint UI
我們使用 vue-cli 來(lái)創(chuàng)建的組件化項(xiàng)目,其實(shí)也有三種引入 Mint UI 的方式
(1)、直接在 index.html 中引入
我們使用 vue-cli 來(lái)創(chuàng)建一個(gè)項(xiàng)目,過(guò)程就不演示了,以前說(shuō)過(guò),我們直接看核心代碼
1)、在 index.html 中使用 cdn 引入 mint-ui 相關(guān)的 css 和 js
<html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width,initial-scale=1.0"> <title>mint-ui-demo</title> <link rel="stylesheet" href="https://unpkg.com/mint-ui/lib/style.css"> </head> <body> <!-- 先引入 Vue --> <script src="https://unpkg.com/vue@2.5.11/dist/vue.js"></script> <!-- built files will be auto injected --> <scrip tsrc="https://unpkg.com/mint-ui/lib/index.js"></script> <div id="app"></div> </body> </html>
配置 externals mint-ui
2)、配置 webpack.base.conf.js,添加如下代碼
配置 mint-ui
我們?cè)?webpack.base.conf.js 的 module.exports 中配置 externals,externals 是把組件公開(kāi)出去,供全局使用
PS:在這里我們要注意一點(diǎn) externals 配置的 key:vaule 形式的,這里的 Value 好多文章中說(shuō)是隨意配置的,但是親過(guò)自己親測(cè),這里不能隨便配置,必須要和相關(guān) js 暴漏出來(lái)的模塊名字一模一樣,對(duì)于 mint-ui 來(lái)說(shuō)是 MINT,我們可以看一下 mint-ui.js 的源碼
看到了吧,mint-ui 暴露出去供我們使用的是 MINT,所以 externals 的 value 一定是這個(gè)值「不能隨意配置」
3、修改 main.js
import MINT from'mint-ui' Vue.use(MINT)
添加以上兩句,引入 mint-ui ,并且使用它
經(jīng)過(guò)以上三部,我們就使用 cdn 的方式把 mint-ui 配置完了,我們來(lái)測(cè)試一下
4、在 App.vue 中的模版中添加以下代碼
<template> <div id="app"> <mt-button type="default">default</mt-button> <mt-button type="primary">primary</mt-button> <mt-button type="danger">danger</mt-button> <router-view/> </div> </template>
5、運(yùn)行查看結(jié)果
怎么樣,完美的顯示出了 mint-ui 的 Button 效果