如何在jQuery Mobile中以优雅的风格动态添加标题栏

时间:2013-04-09 17:23:30

标签: jquery-mobile

我的移动网站动态添加标题栏以减少代码冗余。

但是,我坚持使用jquery移动页面的样式标题部分。

当我看到生成的HTML标记时,它看起来没问题,

但它的元素不是由jQuery Mobile修饰的。

添加内容后,我调用了

$(pageId).trigger('create');

你有什么想法吗?

2 个答案:

答案 0 :(得分:1)

这对我有用:http://jsfiddle.net/emBxx/2/

<强> HTML:

<script type="text/javascript" src="js/main.js"></script>

...

<div data-role="page" data-theme="b">
    <header></header>
    <div data-role="content">
        <div class="content-primary">
            <br />
            <ul data-role="listview" data-filter="true">
                <li><a href="index.html">Some</a></li>
                <li><a href="index.html">random</a></li>
                <li><a href="index.html">searchable</a></li>
                <li><a href="index.html">content</a></li>
                <li><a href="index.html">(list!)</a></li>
            </ul>
        </div><!--/content-primary -->  
    </div>
    <footer></footer>
</div><!-- page end-->
<script>      
    appendJQMHeader('Injected header !'); 
    appendJQMFooter('—Injected ftr!', 'JQM 1.3.1Beta');
</script>

JS,在js / main.js中:

function appendJQMHeader(pageTitle) {
    $('header').replaceWith(
        '<header data-role="header" data-theme="f">'+
        '<h1>'+pageTitle+'</h1>'+
        '<a href="index.html"  data-transition="slide" data-rel="back" data-icon="home" data-iconpos="notext" data-ajax="true">Home</a>'+
        '</header><!-- /header -->');
}

function appendJQMFooter(left, right) {
    $('footer').replaceWith('<footer data-role="footer" data-theme="f" class="jqm-footer"><p>&copy;'+left+'!</p><p class="jqm-version">—'+right+'</p></footer>');
}

注意:对于JSfiddle,它需要&#39; Framework & extension&gt; No wrap - in <head>&#39;
对于独立版本,它适用于html head调用包含JS的js / main.js。那么html正文appendJQMHeader()&amp; appendJQMFooter()。看小提琴:)

答案 1 :(得分:0)

我没有调用触发器方法,而是执行了下面的命令,它运行良好。

$('#pageHome').closest(":jqmData(role='page')").trigger('pagecreate');