jquery mobile中用js代码改变按钮样式的问题

最近用jquery mobile做一个应用,其中设计了一个左右各一个按钮的按钮组,然后想在代码里面写成在一定条件下将按钮设为disable,否则设为enable。
我在html中是这样写的
<div data-role="controlgroup" id="group" data-type="horizontal" style="text-align: center;">
<a href="javascript:goHome()" data-role="button" data-icon="home"
data-theme="a" id="homeBtn" class="ui-disabled">Home</a>
<a href="javascript:goBack()" data-role="button" data-icon="back"
data-theme="a" id="backBtn" class="ui-disabled">Back</a>
</div>

在javascript中是这样写的

if(currentPath == 'file:///sdcard'){
$("#homeBtn").attr("class", "ui-disabled");
$("#backBtn").attr("class", "ui-disabled");
}else{
$("#homeBtn").removeAttr("class");
$("#backBtn").removeAttr("class");
}

这样写本身应该没问题,可是实际运行却不行,后来我看了
[url]http://www.wglong.com/main/artical!details?id=4[/url]这篇博客,里面提到了jquery mobile各类组件在改变值后要刷新,然后想到之前用的listview和select这两个控件刷新的问题,觉得应该也是要刷新一下。我又加了按钮的刷新:

if(currentPath == 'file:///sdcard'){
$("#homeBtn").attr("class", "ui-disabled");
$("#backBtn").attr("class", "ui-disabled");
}else{
$("#homeBtn").removeAttr("class");
$("#backBtn").removeAttr("class");
}
$("#homeBtn").buttonMarkup( "refresh" );
$("#backBtn").buttonMarkup( "refresh" );

这样之后,按钮确实按我设定的条件显示disable或enable了,但是原本左右并排的两个按钮变为了上下并排,后来又想到是要把controlgroup也刷新一下,加上
$("#group").controlgroup("refresh");

接着我又发现还有一个问题,那就是按钮原本的圆角没了,都变成了直角,我百度后搜到了这篇文章[url]http://www.itlead.com.cn/article/html/148/2012-02-01/content-7679.shtml[/url]给了我启发。我查过jquery mobile的源码后发现有ui-btn-corner-all这个class,所以又把代码改成

if(currentPath == 'file:///sdcard'){
$("#homeBtn").attr("class", "ui-disabled");
$("#backBtn").attr("class", "ui-disabled");
}else{
$("#homeBtn").removeAttr("class");
$("#backBtn").removeAttr("class");
}
$("#homeBtn").buttonMarkup( "refresh" );
$("#homeBtn").addClass("ui-btn-corner-all");
$("#backBtn").buttonMarkup( "refresh" );
$("#backBtn").addClass("ui-btn-corner-all");
$("#group").controlgroup("refresh");

我感觉jquery mobile的官方api还是写的太简单,尤其是方法和事件部分,而且移动web框架的应用还不是很广泛,网上能查到的很少,所以才让我解决这么个小问题都费了这么大番周折。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值