ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

javascript-jQuery Mobile:更新导航栏时替代.trigger(‘create’)或.page()吗?

2019-11-01 18:35:20  阅读:246  来源: 互联网

标签:dom jquery-mobile html javascript jquery


我有以下jQuery Mobile HTML代码,导航栏的内容是使用javascript设置的.静态设置时,jQuery mobile设置导航栏的样式,但是稍后在使用javascript设置导航栏(html)的内容时,您必须做一些额外的工作才能使其正常工作:
    

    <div data-role="header">
        <h1 id="title">App</h1>
    </div><!-- /header -->

    <div data-role="content" id="content">    
        <p>Loading...</p>
    </div><!-- /content -->

    <div data-role="footer" data-position="fixed">
        <div data-role="navbar" id="navbar">
            <ul id="menu">
            </ul>
        </div>
    </div><!-- /footer -->
</div><!-- /page -->

触发器(‘创建’);通常用于解决使用javascript / ajax设置时未标记样式的问题.但是,它似乎只能在data-role =“ content”内运行,而不适用于#navbar.下面的脚本应该可以工作,但是菜单没有样式设置.

$(function(){
    $("#menu").html("<li><a href='#'>Test Styling</a></li>").trigger('create');
});

任何想法如何解决这个问题?我已经尝试过page();和.listview(‘refresh’);没有结果.

解决方法:

追加列表项后,尝试调用navbar方法:

$(function(){
    $("#menu").html("<li><a href='#'>Test Styling</a></li>");
    $("#navbar").navbar(); 
});

编辑:
您也可以尝试动态创建导航栏:

var footer = $("#footer-id");

var navBar = $("div", {
    "data-role":"navbar",
    "html":"<ul><li><a href='#'>Test Styling</a></li></ul>"
}).appendTo(footer).navbar();   

标签:dom,jquery-mobile,html,javascript,jquery
来源: https://codeday.me/bug/20191101/1985646.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有