在jQuery mobile 1.4.0中使用data-prefetch

时间:2014-02-10 21:09:48

标签: jquery-mobile prefetch

在我的jQuery移动应用程序中,我使用了数据预取来预取Page1,以提高性能,因为每个页面都需要时间打开并在点击链接后显示给用户,问题是当我点击在Page1链接上,一旦应用程序被启动,Page1的pageinit / pagecreate事件没有被执行,在这种情况下我从数据库返回数据以显示在弹出列表视图中,但是当我回到主页然后单击Page1链接a获得执行的Pageinit事件和返回的数据。

为什么Pageinit / pagecreate事件在预取页面时不起作用?我怎么解决这个问题 ?因为在Pagecreate或Pageinit事件中返回数据非常重要

我遇到的另一个问题是,当我从Page1回到主页时,主页链接变得不起作用我单击Page1链接但是Page1没有打开,即使我多次单击链接它也没有打开Page1 ..我怎么能解决这个问题?请帮帮我

主页

<div data-role="page" id="home">
<div data-role="header" data-position="fixed">
     <h1>Header - Home</h1>

</div>
<div data-role="content"></div>
<a href="Page1.html" data-transition="none"  class="ui-btn"  data-role="button" data-prefetch="true" >Page1</a>
 <a href="Page2.html" data-transition="none"  class="ui-btn"  data-role="button" data-prefetch="true" >Page2</a>

<div data-role="footer" data-position="fixed">
     <h1>Footer</h1>

     </div>
 </div>

第1页

<div data-role="page" id="Page1">
     <div data-role="header" data-position="fixed">
       <h1>Header - Page 1</h1>

      </div>
      <div data-role="content">

       <a href="MyPOPUP" data-rel="popup" class="ui-btn  ui-corner-all" data-   inline="true">Show Popup</a>

       </div>
       <div data-role="popup" id="MyPOPUP" data-position-to="window" data-  corners="false" data- overlay-theme="a" data-dismissible="false">
       <div data-role="header" data-theme="a">

           <div style="text-align:center;float:center;padding-top:11px;">
           <font size="6px" color="white">Employees</font>

           </div>
        </div>
       <div id="scrollContent" data-role="content">
      <ul data-role="listview" id="EmpList" style="margin: 0 !important;">

      </ul>
     </div>
   </div>
</div>

Page1.js

  document.addEventListener('deviceready', onDeviceReady, false);


  function   onDeviceReady() 
  {

       $('#Page1').on('pageinit',function(event){


           db.transaction(getAllEmployees, transactionError); 

       });

   }

  function getAllEmployees(tx)
  {
      tx.executeSql('SELECT EmpName,Salary,Gender,Country  FROM  Employee',           [],getEmpSuccess,transactionError);

  }

 function  getEmpSuccess(tx,result)
 {    

     if (result.rows.length)
     {


         for(var i=0;i< result.rows.length; i++)
         {     
            var row = result.rows.item(i);
            $('#EmpList').append('<li><a href="#">' +'<font class="line1">' + '         '+row['EmpName']+ '</font>' +'<font size="6px" class="line2" > '+ row['Gender']  +'</font>'+'<font size="6px" class="line3"> ' +row['Country']+' </font>'+'<font  size="6px" class="line4"> '+ row['Salary']+'</font><BR> '+'</a><a href="#" >Delete</a></li>' );

                                                                                                                                                                                                                    }
 } 
 $('#EmpList').listview('refresh');
} 

0 个答案:

没有答案