DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> jQuery入門知識 >> JQuery特效代碼 >> jquery mobile動態添加元素之後不能正確渲染解決方法說明
jquery mobile動態添加元素之後不能正確渲染解決方法說明
編輯:JQuery特效代碼     

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";
});

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved