jquery mobile中用js代码改变按钮样式的问题
最近用jquerymobile做一个应用,其中设计了一个左右各一个按钮的按钮组,然后想在代码里面写成在一定条件下将按钮设为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"); }
这样写本身应该没问题,可是实际运行却不行,后来我看了
http://www.wglong.com/main/artical!details?id=4这篇博客,里面提到了jquerymobile各类组件在改变值后要刷新,然后想到之前用的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");
接着我又发现还有一个问题,那就是按钮原本的圆角没了,都变成了直角,我百度后搜到了这篇文章http://www.itlead.com.cn/article/html/148/2012-02-01/content-7679.shtml给了我启发。我查过jquerymobile的源码后发现有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");
我感觉jquerymobile的官方api还是写的太简单,尤其是方法和事件部分,而且移动web框架的应用还不是很广泛,网上能查到的很少,所以才让我解决这么个小问题都费了这么大番周折。
相关推荐
88274956 2020-11-03
runner 2020-09-01
梦的天空 2020-08-25
移动开发与培训 2020-08-16
ReunionIsland 2020-08-16
lyqdanang 2020-08-16
MyNameIsXiaoLai 2020-07-08
星辰的笔记 2020-07-04
csstpeixun 2020-06-28
letheashura 2020-06-26
liaoxuewu 2020-06-26
sunzhihaofuture 2020-06-21
FEvivi 2020-06-16
坚持着执着 2020-06-16
waterv 2020-06-14
xiaoge00 2020-06-14
firejq 2020-06-14
firstboy0 2020-06-14
e度空间 2020-06-12
zhongweinan 2020-06-10