首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >ASP.Net/Ruby/PHP网站、jQuery移动和Phonegap

ASP.Net/Ruby/PHP网站、jQuery移动和Phonegap
EN

Stack Overflow用户
提问于 2012-05-05 19:28:06
回答 2查看 2.2K关注 0票数 3

我有一个ASP.Net MVC3应用程序(不管是ASP.NET MVC、PHP还是RAILS,因为它最终提供的是编程HTML),它使用jquery,在所有移动浏览器中都工作得很好。我的下一步是使用Phonegap创建一个本地ios应用程序。

我的猜测是,我所要做的就是在我放在Phonegap中的html页面中,我将连接到页面加载事件,并从远程服务器动态加载MVC视图的内容。

但我正在寻找一些例子,如果其他人做了类似的事情。

-Thanks预置尼克

更新:I能够通过编写下面的index.html页面来完成这一任务。希望它能帮到别人。

仍然存在问题,尽管:但是在完成了this...as之后,您可能会注意到,我正在通过http://IP:8081 URL请求ASP.NET MVC页面。这很好,它加载我的页面too...but --它不是jquery格式化的。所以,如果有人能帮我,那就太好了。

解释:因为,ajax.responseText包含从<!DOCTYPE html>标记开始的整个<!DOCTYPE html>.我认为很明显,我最后在我的<div data-role="page" id="home">标记中插入了整个HTML页面,这显然是错误的,但我还没有一个解决方案:

代码语言:javascript
运行
复制
<!DOCTYPE html>
<html>
<head>
    <title>PhoneGap Ajax Sample</title>
    <meta name="viewport" content="width=device-width,initial-scale=1, target-densityDpi=device-dpi"/>
    <link rel="stylesheet" href="http://code.jquery.com/mobile/1.1.0/jquery.mobile-1.1.0.min.css" />
    <script type="text/javascript"  src="http://code.jquery.com/jquery-1.6.4.min.js"></script>
    <script type="text/javascript"  src="http://code.jquery.com/mobile/1.1.0/jquery.mobile-1.1.0.min.js"></script>
    <script type="text/javascript" charset="utf-8" src="phonegap.js"></script>
    <script type="text/javascript">
        function onDeviceReady() {
            var ajax = new XMLHttpRequest();
            ajax.open("GET", "http://192.168.2.30:8081/", true);
            ajax.send();

            ajax.onreadystatechange = function () {
                alert(ajax.status);
                if (ajax.readyState == 4 && (ajax.status == 200 || ajax.status == 0)) {
                    document.getElementById('home').innerHTML = ajax.responseText;
                }
            }
        }

        $(document).bind("mobileinit", function () {
            alert('mobileinit');
            // Make your jQuery Mobile framework configuration changes here!
            $.support.cors = true;
            $.mobile.allowCrossDomainPages = true;
        });

        document.addEventListener("deviceready", onDeviceReady, false);
    </script>
</head>
<body>
     <div data-role="page" id="home"> 
     </div>
     <div data-role="page" id="search"> 
     </div>
     <div data-role="page" id="recent"> 
     </div>
</body>
</html> 
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-05-23 23:37:09

为什么不使用jQuery助手从远程服务器加载页面。

代码语言:javascript
运行
复制
$(document).bind("mobileinit", function () {
     alert('mobileinit');
     // Make your jQuery Mobile framework configuration changes here!
     $.support.cors = true;
     $.mobile.allowCrossDomainPages = true;
     $("#home").load('http://192.168.2.30:8081/ #targetContent');
});

加载方法可以发出请求并用ajax请求的结果替换选择器的内容。它还允许您在URL之后提供一个选择器,该选择器将针对要加载到原始匹配选择器中的远程服务器中的特定内容。

票数 3
EN

Stack Overflow用户

发布于 2012-05-07 01:39:09

据我所知,从广义上讲,PhoneGap有两个选项(我还没有亲自尝试过)。(现在我正在了解它们):

  1. 您可以在您的PhoneGap开发环境中安装iOS,它允许您从iOS生成一个原生的iOS应用程序。
  2. 在PhoneGap网站上,你上传你的网页应用程序,它们会生成你的iOS (或安卓)应用程序二进制。
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10465242

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档