javascript - jQuery Mobile ListView 尝试通过应用 'ui-btn-active' 类来突出显示所选元素不起作用。有没有 'selected'类

标签 javascript jquery html css jquery-mobile

我有几个 jquery-mobile 页面和一个充当侧边菜单的全局面板。当面板出现以指示哪个页面当前处于事件状态时,我需要突出显示列表项。

演示页面位于: https://jsfiddle.net/pengyanb/btm7es4m/7/

我尝试将'ui-btn-active'类添加到'li'元素('li'元素不包含任何'a'子元素),似乎没有效果。 有没有类可以应用于listview的'li'元素实现高亮效果? 提前致谢。

$('#globalPanel').panel().enhanceWithin();

$('#gotoPage1').unbind().click(function(){
    $.mobile.changePage("#page1", {transition: "flip"});
});
$('#gotoPage2').unbind().click(function(){
    $.mobile.changePage("#page2", {transition: "flip"});
});

$('#globalPanel').off().on('panelbeforeopen', function(event, ui){
    $('#globalPanel').find('li').removeClass('ui-btn-active');
    if($.mobile.activePage.attr('id') === 'page1')
    {
        console.log("Trying to highlight Panel item1");
        $('#gotoPage1').addClass('ui-btn-active');
    }
    else if($.mobile.activePage.attr('id') === 'page2')
    {
        console.log("Trying to highlight Panel item2");
        $('#gotoPage2').addClass('ui-btn-active');
    }
    $('#globalPanel').find('ul').listview('refresh');
});
<!--Page 1-->
<div data-role="page" id="page1" data-theme="a">
            <!--header-->
            <div data-role="header" data-position="fixed">
                <a href="#globalPanel" class="ui-btn ui-btn-left ui-icon-bars ui-btn-icon-notext ui-corner-all"></a>
                <h5>Page 1</h5>
            </div>
            <!--content-->
            <div data-role="main" class="ui-content">
            </div>
</div>
<!--Page 2-->
 <div data-role="page" id="page2" data-theme="a">
            <!--header-->
            <div data-role="header" data-position="fixed">
                <a href="#globalPanel" class="ui-btn ui-btn-left ui-icon-bars ui-btn-icon-notext ui-corner-all"></a>
                <h5>Page 2</h5>
            </div>
            <!--content-->
            <div data-role="main" class="ui-content">
            </div>
</div>

<!--Global Panel-->
<div data-role="panel" id="globalPanel" data-transition="reveal" data-position-fixed="true" data-position="left" data-theme="b">
    <ul data-role="listview" data-inset="false" data-corners="false">
        <li id="gotoPage1">Page 1</li>
        <li id="gotoPage2">Page 2</li>
    </ul>
</div>

最佳答案

默认情况下,ui-btn-active不适用于普通 <li>元素。所以你可以只添加这个 CSS:

li.ui-btn-active {
    background-color:       #22aadd !important;
    border-color:           #22aadd !important;
    color:                  #fff !important;
    text-shadow: 0 0 #0088bb !important;
}

Updated FIDDLE

关于javascript - jQuery Mobile ListView 尝试通过应用 'ui-btn-active' 类来突出显示所选元素不起作用。有没有 'selected'类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31821399/

相关文章:

javascript - 为什么 Facebook、Disqus、Google、Twitter 等服务告诉我们

html - overflow hidden 的div中的图片如何显示?

html - 用于转到 URL 的单选按钮

javascript - 如何让 javascript 加载速度更快?

javascript - 无法将坐标精确到 Canvas

javascript - jQuery 覆盖 : Closing current overlay and opening another?

javascript - 如何将日期范围拆分为时间间隔?

php - 如何用 Amazon S3 替换 PHP imagecopyresampled?

javascript - 在字符串/cookie 中的特定单词之前抓取字符

javascript - X-Frame-Options 错误