萬盛學電腦網

 萬盛學電腦網 >> 腳本專題 >> javascript >> jquery mobile動態添加元素之後不能正確渲染解決方法說明

jquery mobile動態添加元素之後不能正確渲染解決方法說明

 本篇文章主要是對jquery mobile動態添加元素之後不能正確渲染解決方法進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助

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"; });  
copyright © 萬盛學電腦網 all rights reserved