0

我正在尝试更改变量的值,我按照这篇文章中的说明进行了操作,但值没有改变。

我的代码如下:

Ext.define('MyApp.view.OnlineOffline', {
extend: 'Ext.Panel',  
alias: "widget.onlineoffline", 

config: {    
onlineStatus: 0,
items: [
{
xtype: 'container',
layout: 'hbox',     
cls: 'offline-wrap',
items:[
{

xtype: 'image',
cls: 'offlineCheck',
id:'onlineButton',      
width: 85,      
height:20,      
listeners: {
tap: function (button) 
{
var me = button.up('onlineoffline')
if (!Ext.device.Connection.isOnline()) 
{
 Ext.Msg.alert('Please connect to <br/>working internet Connection?');
 this.element.removeCls('onlineCheck');
 this.element.addCls('offlineCheck');
 me.setonlineStatus(1);
 } 
 else {
if(me.getOnlineStatus())
{  
console.log( 'connection yes if' + me.getOnlineStatus());                   
me.setOnlineStatus(1);
this.element.removeCls('onlineCheck');
this.element.addCls('offlineCheck');
}
else{
this.element.removeCls('offlineCheck');
this.element.addCls('onlineCheck'); 
me.setOnlineStatus(0);
console.log( 'connection yes else' + me.getOnlineStatus());                                      
} 
}
}
}
},          
]
}]
}
});
4

1 回答 1

1

这里有几件事......

首先,您将初始化me为全局变量,这是一个坏主意。不要这样做,而是参考您me使用按钮所拥有的内容:

listeners: {
    tap: function (button) {
        var me = button.up('onlineoffline')
        ...

您遇到的问题是因为您调用了错误的函数。您的config参数定义为onlineStatus,但您正在调用setonlinestatus()me.setOnlineStatus()改为打电话。生成的 getter 和 setter 的驼峰式大小写将完全按照您的config参数完成,除了第一个字母将大写。

于 2013-08-27T11:46:32.360 回答