溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

發(fā)布時間:2020-04-06 14:34:38 來源:網(wǎng)絡(luò) 閱讀:327 作者:wx5d51393e4bd0e 欄目:開發(fā)技術(shù)

我們在使用目前最主流的前端框架vue在開發(fā)過程中,組件是一個非常重要的組成部分,可以這么說,所有的vue 應(yīng)用,都是由一個一個的小組件拼裝而成的。
正是由于vue組件如此重要,所以vue的生態(tài)中,也非常多的UI組件庫,其中最著名的非Element-UI莫屬,里面有非常多的封裝完善的組件提供給我們使用,大大的增強(qiáng)了我們的開發(fā)效率。
那么,這些UI框架的組件,究竟是如何封裝的呢?如何動手從零開始封裝自己的組件呢?接下來,我們就從最簡單的一個Button的組件封裝說起。如下,是Element-UI中的按鈕組件,接下來,我們就一步一步來實現(xiàn)它們。

源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

首先,定義一個組件index.vue,配置路由渲染出來源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

其次,自己定義一個組件my-butotn, 寫好基本的樣式,按鈕中間,使用插槽<slot/>占位。
寫好按鈕的基本樣式,代碼如下源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

效果如下:源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

然后,我們先來實現(xiàn)type屬性,根據(jù)type的不同,渲染不同的默認(rèn)顏色效果,主要是通過傳入的type不同,里面渲染不同的類,實現(xiàn)不同的樣式效果,核心代碼如下源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件
源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

實現(xiàn)出來的效果如下圖:
源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

接下來,我們來實現(xiàn)size屬性,通過傳入不同的size,實現(xiàn)不同的尺寸的按鈕的控制。
核心代碼如下:源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

}
源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

實現(xiàn)效果如下:源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

那么,我們還可以控制按鈕是否是圓角按鈕,通過設(shè)計一個屬性round,如果在使用按鈕的時候,傳入了屬性round,那么這個按鈕就是圓角按鈕。代碼如下

源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件
源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件
源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件
實現(xiàn)的效果如下:源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

最后,我們來實現(xiàn)以下按鈕的應(yīng)用效果,只要在使用自定義組件的時候,傳入diabled屬性,那么禁用效果就生效,否則,效果就不生效。代碼如下源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件:源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

最終實現(xiàn)效果如下:
源碼時代前端干貨分享|從零動手封裝一個通用的vue按鈕組件

綜上所述,我們就一步一步的動手,從零實現(xiàn)了一個通用的按鈕組件,實現(xiàn)了type控制按鈕的表現(xiàn)效果,size控制按鈕的尺寸,round屬性控制按鈕是否是圓角,和disable屬性控制按鈕是否禁用,那么其他組件的封裝其實也大同小異,請大家持續(xù)關(guān)注后續(xù)文章。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI