vue中ant-design-vue組件的安裝與使用
官方地址:Ant Design Vue
1. 安裝
首先使用vue-cli創(chuàng)建項(xiàng)目,然后進(jìn)入項(xiàng)目,使用npm安裝ant-design-vue庫:
npm i --save ant-design-vue@next
然后在package.json文件中的dependencies中看見剛剛下載的庫:
2. 引入組件庫
然后在main.js中引入,注意要按照順序:
# 引入組件庫 import ant from 'ant-design-vue' # 引入樣式表 import 'ant-design-vue/dist/antd.css'
引入順序如圖所示:
接著需要use該組件庫的句柄:
然后在要使用的vue文件中也引入組件庫,比如我要在項(xiàng)目默認(rèn)的App.vue中使用組件庫:
import 'ant-design-vue/dist/antd'
3. 使用
3.1 按鈕樣式
直接將代碼復(fù)制到component標(biāo)簽中即可,要注意component標(biāo)簽中只能允許有一個(gè)根標(biāo)簽。
3.2 導(dǎo)航欄樣式
可以選擇顏色的導(dǎo)航欄
<template> <div> <a-switch :checked="mode === 'vertical'" @change="changeMode" /> Change Mode <span class="ant-divider" style="margin: 0 1em" /> <a-switch :checked="theme === 'dark'" @change="changeTheme" /> Change Theme <br /> <br /> <a-menu style="width: 256px" v-model:openKeys="openKeys" v-model:selectedKeys="selectedKeys" :mode="mode" :theme="theme" > <a-menu-item key="1"> <template #icon> <MailOutlined /> </template> Navigation One </a-menu-item> <a-menu-item key="2"> <template #icon> <CalendarOutlined /> </template> Navigation Two </a-menu-item> <a-sub-menu key="sub1"> <template #icon> <AppstoreOutlined /> </template> <template #title>Navigation Three</template> <a-menu-item key="3">Option 3</a-menu-item> <a-menu-item key="4">Option 4</a-menu-item> <a-sub-menu key="sub1-2" title="Submenu"> <a-menu-item key="5">Option 5</a-menu-item> <a-menu-item key="6">Option 6</a-menu-item> </a-sub-menu> </a-sub-menu> <a-sub-menu key="sub2"> <template #icon> <SettingOutlined /> </template> <template #title>Navigation Four</template> <a-menu-item key="7">Option 7</a-menu-item> <a-menu-item key="8">Option 8</a-menu-item> <a-menu-item key="9">Option 9</a-menu-item> <a-menu-item key="10">Option 10</a-menu-item> </a-sub-menu> </a-menu> </div> </template> <script> import { defineComponent, reactive, toRefs } from 'vue'; import { MailOutlined, CalendarOutlined, AppstoreOutlined, SettingOutlined, } from '@ant-design/icons-vue'; export default defineComponent({ setup() { const state = reactive({ mode: 'inline', theme: 'light', selectedKeys: ['1'], openKeys: ['sub1'], }); const changeMode = checked => { state.mode = checked ? 'vertical' : 'inline'; }; const changeTheme = checked => { state.theme = checked ? 'dark' : 'light'; }; return { ...toRefs(state), changeMode, changeTheme }; }, components: { MailOutlined, CalendarOutlined, AppstoreOutlined, SettingOutlined, }, }); </script>
頂部導(dǎo)航欄
<template> <a-menu v-model:selectedKeys="current" mode="horizontal"> <a-menu-item key="mail"> <template #icon> <mail-outlined /> </template> Navigation One </a-menu-item> <a-menu-item key="app" disabled> <template #icon> <appstore-outlined /> </template> Navigation Two </a-menu-item> <a-sub-menu> <template #icon> <setting-outlined /> </template> <template #title>Navigation Three - Submenu</template> <a-menu-item-group title="Item 1"> <a-menu-item key="setting:1">Option 1</a-menu-item> <a-menu-item key="setting:2">Option 2</a-menu-item> </a-menu-item-group> <a-menu-item-group title="Item 2"> <a-menu-item key="setting:3">Option 3</a-menu-item> <a-menu-item key="setting:4">Option 4</a-menu-item> </a-menu-item-group> </a-sub-menu> <a-menu-item key="alipay"> <a target="_blank" rel="noopener noreferrer"> Navigation Four - Link </a> </a-menu-item> </a-menu> </template> <script> import { defineComponent, ref } from 'vue'; import { MailOutlined, AppstoreOutlined, SettingOutlined } from '@ant-design/icons-vue'; export default defineComponent({ setup() { const current = ref(['mail']); return { current, }; }, components: { MailOutlined, AppstoreOutlined, SettingOutlined, }, }); </script>
3.3 表單樣式
內(nèi)聯(lián)登錄欄
<template> <a-form layout="inline" :model="formState" @finish="handleFinish" @finishFailed="handleFinishFailed" > <a-form-item> <a-input v-model:value="formState.user" placeholder="Username"> <template #prefix><UserOutlined style="color: rgba(0, 0, 0, 0.25)" /></template> </a-input> </a-form-item> <a-form-item> <a-input v-model:value="formState.password" type="password" placeholder="Password"> <template #prefix><LockOutlined style="color: rgba(0, 0, 0, 0.25)" /></template> </a-input> </a-form-item> <a-form-item> <a-button type="primary" html-type="submit" :disabled="formState.user === '' || formState.password === ''" > Log in </a-button> </a-form-item> </a-form> </template> <script> import { UserOutlined, LockOutlined } from '@ant-design/icons-vue'; import { defineComponent, reactive } from 'vue'; export default defineComponent({ setup() { const formState = reactive({ user: '', password: '', }); const handleFinish = values => { console.log(values, formState); }; const handleFinishFailed = errors => { console.log(errors); }; return { formState, handleFinish, handleFinishFailed, }; }, components: { UserOutlined, LockOutlined, }, }); </script>
補(bǔ)充:ant-design-vue的兼容問題
問題:ant-design-vue不兼容ie瀏覽器
要求:ie兼容 >= 9
環(huán)境:vue cli3搭建項(xiàng)目,ant-design-vue@1.3.8
babel.config.js文件
module.exports = { presets: [ '@vue/app', // 兼容配置 [ '@babel/preset-env', { 'useBuiltIns': 'entry' } ] ], // 按需加載配置 plugins: [ [ 'import', { libraryName: 'ant-design-vue', libraryDirectory: 'es', style: 'css' }, ] ] }
main.js文件(項(xiàng)目入口)
// 引入@babel/polyfill處理兼容? import '@babel/polyfill' import Vue from 'vue' import App from './App.vue' import router from './router/router' import store from './store/store' import './plugins/antd.js' new Vue({ ? router, ? store, ? render: h => h(App) }).$mount('#app')
總結(jié)
到此這篇關(guān)于vue中ant-design-vue組件安裝與使用的文章就介紹到這了,更多相關(guān)vue ant-design-vue組件使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue echarts模擬后端數(shù)據(jù)流程詳解
在平常的項(xiàng)目中,echarts圖表我們也是使用的非常多的,通常我們從后端拿到數(shù)據(jù),需要在圖表上動態(tài)的進(jìn)行呈現(xiàn),接下來我們就模擬從后端獲取數(shù)據(jù)然后進(jìn)行呈現(xiàn)的方法2022-09-09vuejs實(shí)現(xiàn)本地?cái)?shù)據(jù)的篩選分頁功能思路詳解
今天做項(xiàng)目需要一份根據(jù)本地?cái)?shù)據(jù)的篩選分頁功能,下面小編把vuejs實(shí)現(xiàn)本地?cái)?shù)據(jù)的篩選分頁功能的實(shí)現(xiàn)思路分享到腳本之家平臺,需要的朋友可以參考下2017-11-11Vue實(shí)現(xiàn)網(wǎng)頁首屏加載動畫及頁面內(nèi)請求數(shù)據(jù)加載loading效果
Loading加載動畫組件看起來很簡單不重要,實(shí)際上它是保證用戶留存的關(guān)鍵一環(huán),下面這篇文章主要給大家介紹了關(guān)于Vue實(shí)現(xiàn)網(wǎng)頁首屏加載動畫及頁面內(nèi)請求數(shù)據(jù)加載loading效果的相關(guān)資料,需要的朋友可以參考下2023-02-02如何解決vuex在頁面刷新后數(shù)據(jù)被清除的問題
這篇文章主要介紹了如何解決vuex在頁面刷新后數(shù)據(jù)被清除的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05vue踩坑記-在項(xiàng)目中安裝依賴模塊npm install報(bào)錯(cuò)
這篇文章主要介紹了vue踩坑記-在項(xiàng)目中安裝依賴模塊npm install報(bào)錯(cuò),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04Vue Echarts實(shí)現(xiàn)圖表的動態(tài)適配以及如何優(yōu)化
這篇文章主要介紹了Vue Echarts實(shí)現(xiàn)圖表的動態(tài)適配以及如何優(yōu)化,在實(shí)際的前端開發(fā)過程中,動態(tài)適配是一個(gè)非常重要的問題,在數(shù)據(jù)可視化的場景下,圖表的動態(tài)適配尤為重要,需要的朋友可以參考下2023-05-05