sencha touch 模仿tabpanel導(dǎo)航欄TabBar的實(shí)例代碼
基于sencha touch 2.2所寫
代碼:
/*
*模仿tabpanel導(dǎo)航欄
*/
Ext.define('ux.TabBar', {
alternateClassName: 'tabBar',
extend: 'Ext.Toolbar',
xtype: 'tabBar',
config: {
docked: 'bottom',
cls: 'navToolbar',
layout: {
align: 'stretch'
},
defaults: {
flex: 1
},
//被選中的按鈕
selectButton: null
},
initialize: function () {
var me = this;
me.callParent();
//監(jiān)聽按鈕點(diǎn)擊事件
me.on({
delegate: '> button',
scope: me,
tap: 'onButtonTap'
});
},
//更新被選中按鈕
updateSelectButton: function (newItem, oldItem) {
console.log(oldItem);
if (oldItem) {
oldItem.removeCls('x-tabBar-pressing');
}
if (newItem) {
newItem.addCls('x-tabBar-pressing');
}
},
//當(dāng)按鈕被點(diǎn)擊時
onButtonTap: function (button) {
this.setSelectButton(button);
},
/**
* @private
*執(zhí)行添加項,調(diào)用add方法后自動執(zhí)行
*/
onItemAdd: function (item, index) {
if (!this.getSelectButton() && item.getInitialConfig('selected')) {
this.setSelectButton(item);
}
this.callParent(arguments);
}
});
需要的css:
.navToolbar {
padding:0;
}
.navToolbar .x-button {
border:0;
margin:0;
border-right:1px solid #585B5B;
border-radius:0;
padding:0;
}
.navToolbar .x-button .x-button-label {
font-weight:normal;
color:White;
font-size:0.6em;
}
.navToolbar .x-tabBar-pressing {
background-image:none;
background-color:#0f517e;
background-image:-webkit-gradient(linear,50% 0%,50% 100%,color-stop(0%,#0a3351),color-stop(10%,#0c4267),color-stop(65%,#0f517e),color-stop(100%,#0f5280));
background-image:-webkit-linear-gradient(top,#0a3351,#0c4267 10%,#0f517e 65%,#0f5280);
background-image:-moz-linear-gradient(top,#0a3351,#0c4267 10%,#0f517e 65%,#0f5280);
background-image:-o-linear-gradient(top,#0a3351,#0c4267 10%,#0f517e 65%,#0f5280);
background-image:linear-gradient(top,#0a3351,#0c4267 10%,#0f517e 65%,#0f5280);
}
使用:
Ext.define('app.view.MyBar', {
alternateClassName: 'myBar',
extend: 'ux.TabBar',
xtype: 'myBar',
config: {
items: [
{
xtype: 'button',
text: '問卷調(diào)查',
//只有第一個設(shè)置的屬性有效
selected: true
},
{
xtype: 'button',
text: '我的積分'
},
{
xtype: 'button',
text: '開獎大廳'
},
{
xtype: 'button',
text: '幸運(yùn)號碼'
},
{
xtype: 'button',
text: '更多'
}]
}
});
效果圖:

- Android的Touch事件處理機(jī)制介紹
- 淺談Android onTouchEvent 與 onInterceptTouchEvent的區(qū)別詳解
- javascript移動設(shè)備Web開發(fā)中對touch事件的封裝實(shí)例
- Android Touch事件分發(fā)過程詳解
- js的touch事件的實(shí)際引用
- Android中處理apple-touch-icon詳解
- js實(shí)現(xiàn)touch移動觸屏滑動事件
- 淺談javascript的Touch事件
- html5手機(jī)觸屏touch事件介紹
- HTML5實(shí)戰(zhàn)與剖析之觸摸事件(touchstart、touchmove和touchend)
相關(guān)文章
js實(shí)現(xiàn)鼠標(biāo)拖動圖片并兼容IE/FF火狐/谷歌等主流瀏覽器
js實(shí)現(xiàn)鼠標(biāo)拖動圖片做了兼容IE,F(xiàn)F火狐,谷歌等主流瀏覽器,具體實(shí)現(xiàn)代碼如下,感興趣的朋友可以參考下哈,希望對你有所幫助2013-06-06
js彈出層包含flash 不能關(guān)閉隱藏的2種處理方法
js彈出層包含flash 不能關(guān)閉隱藏的2種處理方法,需要的朋友可以參考一下2013-06-06
JavaScript防抖與節(jié)流超詳細(xì)全面講解
在開發(fā)中我們經(jīng)常會遇到一些高頻操作,比如:鼠標(biāo)移動,滑動窗口,鍵盤輸入等等,節(jié)流和防抖就是對此類事件進(jìn)行優(yōu)化,降低觸發(fā)的頻率,以達(dá)到提高性能的目的。本文就教大家如何實(shí)現(xiàn)一個讓面試官拍大腿的防抖節(jié)流函數(shù),需要的可以參考一下2022-10-10
nuxt+axios實(shí)現(xiàn)打包后動態(tài)修改請求地址的方法
這篇文章主要介紹了nuxt+axios實(shí)現(xiàn)打包后動態(tài)修改請求地址的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
ES6模板字符串和標(biāo)簽?zāi)0宓膽?yīng)用實(shí)例分析
這篇文章主要介紹了ES6模板字符串和標(biāo)簽?zāi)0宓膽?yīng)用,結(jié)合實(shí)例形式分析了ES6模板字符串和標(biāo)簽?zāi)0宓墓δ?、原理、用法及相關(guān)操作注意事項,需要的朋友可以參考下2019-06-06
JS的遞增/遞減運(yùn)算符和帶操作的賦值運(yùn)算符的等價式
JS的遞增/遞減運(yùn)算符和帶操作的賦值運(yùn)算符的等價式...2007-12-12
20分鐘成功編寫bootstrap響應(yīng)式頁面 就這么簡單
這篇文章主要教大家如何在20分鐘內(nèi)成功編寫bootstrap響應(yīng)式頁面,其實(shí)很簡單,培養(yǎng)大家分分鐘開發(fā)出一個高大上的頁面能力,感興趣的小伙伴們可以參考一下2016-05-05
JS根據(jù)瀏覽器窗口大小實(shí)時動態(tài)改變網(wǎng)頁文字大小的方法
這篇文章主要介紹了JS根據(jù)瀏覽器窗口大小實(shí)時動態(tài)改變網(wǎng)頁文字大小的方法,涉及JavaScript針對頁面寬高的動態(tài)獲取與元素樣式動態(tài)運(yùn)算的相關(guān)技巧,需要的朋友可以參考下2016-02-02

