且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

如何加载页面使用jquery load()在phonegap

更新时间:2022-10-24 11:12:50

我注意到您的HTML文件 login.html 在您的文件夹 www 中。



可能会尝试通过使用(注意HTML文件的路径)加载HTML文件!


$('。contents') .load('your_login_html_path / login.html');


而不是:


$('.contents').load('http:// localhost:8888 / placeeq / assets / www / pages / login.html');







例如:如果您的html文件(不是 login .html ,另一个调用方法 load())位于文件夹 www ,如果 login.html www - > ,你将有:


$('。contents')。load('./ pages / login.html' );


例如文件夹结构




  • www




    • html_calling_load.html


    • p>


      • login.html

      li>



希望这有帮助。请告诉我们您的结果。


I am trying to load html pages in phonegap using jquery.load() function. but it is not working. It does not load the pages which I want to load. Here is my code

jQuery(function () {
var Login = {
    onDeviceReady : function () {
        $('.contents').load('http://localhost:8888/pc/assets/www/pages/login.html');
    }
};

document.addEventListener("deviceready", Login.onDeviceReady, false);
});

here is my html

<header>
    header
</header>
<section class="contents">
    contents
</section>
<footer>
    <ul class="nav">
        <li><a href="#">Home</a></li>
        <li><a href="#">Profile</a></li>
        <li><a href="#">Photo</a></li>
    </ul>
</footer>

How can I make this work? Please help

Update

cordova.xml file

<?xml version="1.0" encoding="utf-8"?>
<!-- 
   Licensed to the Apache Software Foundation (ASF) under one
   or more contributor license agreements.  See the NOTICE file
   distributed with this work for additional information
   regarding copyright ownership.  The ASF licenses this file
   to you under the Apache License, Version 2.0 (the
   "License"); you may not use this file except in compliance
   with the License.  You may obtain a copy of the License at

     http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing,
   software distributed under the License is distributed on an
   "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
   KIND, either express or implied.  See the License for the
   specific language governing permissions and limitations
   under the License.
 -->
 <cordova>
    <!--  
    access elements control the Android whitelist.  
    Domains are assumed blocked unless set otherwise
     -->

<access origin="*"/> <!-- allow local pages -->

    <!-- <access origin="https://example.com" /> allow any secure requests to example.com -->
    <!-- <access origin="https://example.com" subdomains="true" /> such as above, but including subdomains, such as www -->
    <!-- <access origin=".*"/> Allow all domains, suggested development use only -->

<log level="DEBUG"/>
<preference name="classicRender" value="true" />
 </cordova>

after adding above to cordova.xml file I add this kind of file path in jquery

 jQuery(function () {
var Login = {
    onDeviceReady : function () {
        $('.contents').load('./login.html');
    }
};

document.addEventListener("deviceready", Login.onDeviceReady, false);
 });

I noticed that your HTML file login.html is inside your folder www.

So, I think you may try to load the HTML file by using (pay attention to the path of the HTML file!)

$('.contents').load('your_login_html_path/login.html');

instead of:

$('.contents').load('http://localhost:8888/placeeq/assets/www/pages/login.html');


For example: if your html file (not login.html, the other one which calls the method load()) is in the folder www, and if login.html is in www->pages, you'll have:

$('.contents').load('./pages/login.html');

Eg folder structure:

  • www

    • html_calling_load.html

    • pages

      • login.html

Hope this helps. Let me know about your results.