jquerymobile動態添加元素之後有些不能被正確渲染的解決方法:
listview: 添加 jq(".detail").listview("refresh");
div或其他:添加.trigger( "create" );
======================================================================
jqm在初始化頁面時會根據data-xxx在各元素中插入jqm的屬性和類等。在頁面初始化結束後,如果動態的插入一個元素,往往顯示很丑陋,因為沒有插入jqm的樣式。這個可以用浏覽器裡的開發工具來查看,會發現有些元素多了很多類,而動態插入的元素代碼還是你寫的那樣子。
如果要使動態插入的元素具有jqm的樣式,可以對jqm對象觸發create事件:
. 代碼如下:
<span style="font-size:18px;"> $(selector).trigger('create');</span>
create事件適用范圍廣,甚至可以是 不存在的元素(raw markup?),比如要插入一個按鈕
. 代碼如下:
$('<a data-role="button">dy button</a>').appendTo('#content').trigger('create');
有些對象提供了refresh 方法,如listview、flip toggle。與create的區別是refresh方法需要作用在已存在的對象上,如
$('ul').listview('refresh'),而且refresh只會去更新新加入的元素,如listview裡最新append的元素會更新,原有的保持不變。(不知有沒理解錯,有些沒測試。原文http://stackoverflow.com/questions/7663078/jquery-mobile-page-refresh-mechanism
不使用jqm樣式:
如果不希望jqm自動初始化你的元素,有兩種方法。加入data-role="none"屬性,或者在mobileinit事件中對keepNative選項進行配置
. 代碼如下:
$(document).bind('mobileinit',function(){
$.mobile.page.prototype.options.keepNative = "select, input.foo, textarea.bar";
});