xmlplus組件設(shè)計(jì)系列之按鈕(2)
除了圖標(biāo)以外,按鈕也許是最簡(jiǎn)單的組件了,現(xiàn)在來看看如何定義按鈕組件。
使用原生按鈕組件
在 xmlplus 中,HTML 元素也以組件的方式存在。所以,你可以直接通過使用 button 標(biāo)簽或者 input 標(biāo)簽來使用按鈕組件。如下示例所示:
Example: { xml: "<div id='example'>\ <button>Default</button>\ <input type='submit'>Primary</input>\ </div>" }
雖然原生按鈕外觀不那么吸引人,但原生按鈕未經(jīng)特殊包裝,所以渲染起來最快,執(zhí)行效率最高。
使用 Bootstrap 樣式的按鈕
如果你的項(xiàng)目在視覺上沒有特別要求的話。使用 Bootstrap 樣式來定義按鈕組件是一個(gè)好主意。按傳統(tǒng)方式使用 Bootstrap 按扭,你需要像下面這樣使用。
<button type="button" class="btn btn-default">Default</button> <button type="button" class="btn btn-primary">Primary</button> <button type="button" class="btn btn-success">Success</button>
請(qǐng)認(rèn)真觀察,你是不是覺得它給你的比你要求的要多。你不但發(fā)現(xiàn)了好多的 type=button,還發(fā)現(xiàn)了好多的 btn?,F(xiàn)在下面給出一個(gè)組件,它基于 Bootstrap 樣式,但它明顯地簡(jiǎn)化了按鈕的使用方式。
Button: { xml: "<button type='button' class='btn'/>", fun: function (sys, items, opts) { this.addClass("btn-" + opts.type); } }
此按鈕組件封裝了原始按鈕需要重復(fù)書寫的內(nèi)容,在使用時(shí),僅需提供 type 屬性即可指明目標(biāo)按鈕,使用起來更為便捷。下面給出的是新按鈕組件的使用方式。
<Button type='default'>Default</Button> <Button type='primary'>Primary</Button> <Button type='success'>Success</Button>
帶有圖標(biāo)的按鈕
按鈕上除了文字外,還可以附帶圖標(biāo)。合適的圖標(biāo)可以使按扭的使用意圖更加生動(dòng)直觀。這里以 EasyUI 的圖標(biāo)按鈕為例來說明如何封裝并使用圖標(biāo)按鈕。我們首先來看看,EasyUI 圖標(biāo)按鈕的原始使用方式。
<div style="padding:5px 0;"> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="easyui-linkbutton" data-options="iconCls:'icon-add'">Add</a> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="easyui-linkbutton" data-options="iconCls:'icon-remove'">Remove</a> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="easyui-linkbutton" data-options="iconCls:'icon-save'">Save</a> </div>
與上一節(jié)對(duì) Bootstrap 按鈕的封裝類似,通過觀察提煉出重復(fù)出現(xiàn)的部分,將變化的部分以接口形式展現(xiàn)。上面的按鈕僅圖標(biāo)類型名和文本是可變的,所以我們可以做出如下的設(shè)計(jì):
Button: { xml: "<a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="easyui-linkbutton"/>", fun: function (sys, items, opts) { this.attr("data-options" + "iconCls:'icon-" + opts.type); } }
下面是新圖標(biāo)的使用方式,它明顯比原始的使用方式簡(jiǎn)潔多了。
<div style="padding:5px 0;"> <Button type='add'>Add</Button> <Button type='remove'>Reomve</Button> <Button type='save'>Save</Button> <Button type='cut'>Cut</Button> </div>
自定義你的按鈕組件
使用類似 Bootstrap, EasyUI 等開源框架,可以避免重造輪子。然而,當(dāng)這些開源項(xiàng)目無法滿足你的需求時(shí),你就需要自己動(dòng)手了。
為簡(jiǎn)單起見,現(xiàn)在假定上述 Bootstrap 框架并不存在,那么如何設(shè)計(jì)一套上述的按鈕?這樣的實(shí)踐是非常有意義的,它有助于你舉一反三。
現(xiàn)在讓我們重新對(duì)上面的按鈕組件作觀察。你會(huì)發(fā)現(xiàn),Bootstrap 設(shè)計(jì)了一些可以組合的樣式類,其中 btn 是每一個(gè)按鈕都需要的,另外像 btn-default、btn-primary 等等都根據(jù)需要與 btn 形成組合樣式類。好了,根據(jù)這個(gè)思路,我們就可以設(shè)計(jì)出如下的組件框架。
Button: { css: "#btn { 這里是按鈕基本的樣式 }\ #default { 這里是default樣式 }\ #primary { 這里是primary樣式 }", xml: "<button type='button'/>", fun: function (sys, items, opts) { this.addClass("#btn #" + opts.type, this); } }
上述的設(shè)計(jì)思路與前面直接使用 Bootstrap 樣式定義按鈕不同點(diǎn)在于,前者已經(jīng)為你定義好了各個(gè)全局的樣式類,你只需要直接引用就可以了。而此處你需要在按扭組件內(nèi)部自行定義相關(guān)樣式類。從封裝的角度看,后者的內(nèi)聚性要強(qiáng)于前者,因?yàn)樗⒉槐┞度诸惷?。下面是該組件的使用示例。
Example: { xml: "<div id='example'>\ <Button type='default'>Default</Button>\ <Button type='primary'>Primary</Button>\ <Button type='success'>Success</Button>\ </div>" }
注意,為了簡(jiǎn)化起見,這里的自定義按鈕組件略去了 hover、active 樣式,所以與 Bootstrap 按鈕有些不一樣。
本系列文章基于 xmlplus 框架。如果你對(duì) xmlplus 沒有多少了解,可以訪問 www.xmlplus.cn。這里有詳盡的入門文檔可供參考。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- xmlplus組件設(shè)計(jì)系列之網(wǎng)格(DataGrid)(10)
- xmlplus組件設(shè)計(jì)系列之文本框(TextBox)(3)
- xmlplus組件設(shè)計(jì)系列之選項(xiàng)卡(Tabbar)(5)
- xmlplus組件設(shè)計(jì)系列之下拉刷新(PullRefresh)(6)
- xmlplus組件設(shè)計(jì)系列之路由(ViewStack)(7)
- xmlplus組件設(shè)計(jì)系列之分隔框(DividedBox)(8)
- xmlplus組件設(shè)計(jì)系列之樹(Tree)(9)
- xmlplus組件設(shè)計(jì)系列之列表(4)
- xmlplus組件設(shè)計(jì)系列之圖標(biāo)(ICON)(1)
相關(guān)文章
JavaScript中的Window.open()用法示例詳解
這篇文章主要給大家介紹了關(guān)于JavaScript中Window.open()用法的相關(guān)資料,今天在項(xiàng)目中用到了彈出子窗口,就想到了用JavaScript實(shí)現(xiàn)的兩種方法,其中一個(gè)就是window.open(),需要的朋友可以參考下2023-07-07服務(wù)端渲染nextjs項(xiàng)目接入經(jīng)驗(yàn)總結(jié)分析
這篇文章主要為大家介紹了服務(wù)端渲染nextjs項(xiàng)目接入經(jīng)驗(yàn)總結(jié)分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11淺析Javascript中“==”與“===”的區(qū)別
這篇文章主要介紹了淺析Javascript中“==”與“===”的區(qū)別,非常的全面,這里推薦給小伙伴們2014-12-12JS輕松實(shí)現(xiàn)CSS設(shè)置,DIV+CSS常用CSS設(shè)置
JS輕松實(shí)現(xiàn)CSS設(shè)置,DIV+CSS常用CSS設(shè)置...2007-02-02微信小程序?qū)崿F(xiàn)菜單左右聯(lián)動(dòng)
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)菜單左右聯(lián)動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05對(duì)于Form表單reset方法的新認(rèn)識(shí)
HTML中Form表單的reset方法被用來清空用戶所輸入的內(nèi)容,以前一直誤以為其是單純的將input等輸入項(xiàng)中的值清空2014-03-03