gpt4 book ai didi

javascript - Phonegap、jQueryMobile 和 Web 服务

转载 作者:塔克拉玛干 更新时间:2023-11-02 21:57:00 25 4
gpt4 key购买 nike

我使用 Android SDK 和 java 包创建了一个 native Android 应用程序,使用我创建的 ASP.Net Web 服务,它运行良好。但是现在我想做这个跨平台的。我听说 Phonegap 和 jQuery Mobile 可以帮助解决这个问题,但我还是有点困惑。

  1. 是否需要托管使用 Javascript 的 HTML 文件才能正常工作?或者
  2. 我可以在我的应用程序中包含 HTML 和 js 文件并调用网络服务方法吗?

有人可以指导我吗?

我的演示代码是

Java 脚本

<script type="text/javascript" charset="utf-8" src="phonegap.js"></script>
<script src="jquery-1.7.2.min"></script>
<script src="jquery.mobile-1.1.1.min.js"></script>
<script type="text/javascript" charset="utf-8"/></script>

<link rel="stylesheet" src="jquery.mobile-1.1.1.min.css"/>
<script type="text/javascript">


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

function LoginButton_onclick() {
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8",
dataType: "json",
url: "http://182.72.192.18/webservicedemo/service.asmx/HelloWorld",
data: '{}',
success: function(msg) {
jsonArray = $.parseJSON(msg.d);
var $ul = $( '<ul id="details">' );
for(i=0; i < jsonArray.length; i++)
{
$("#details").append('<li id="'+i+'" name="head" >'+jsonArray[i].name+'</li>' );
} $('#details').listview('refresh');
},
error: function(msg) {
alert("Error");
}
});

</script>

HTML

<div data-role="page" id="Page1">
<h1>DEMO PAGE</h1>

<div id="DEMO">
<input id="LoginButton" type="button" value="GET DATA" onclick="LoginButton_onclick()" /></div>

<div id="divList" data-role="content">
<ul id="details" data-role="listview" data-inset="true"></ul>
</div>

</div>
</body>

我的 ASP.NET Web 服务是

[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.Web.Script.Services.ScriptService]
public class Service : System.Web.Services.WebService{
JavaScriptSerializer serializer = new JavaScriptSerializer();
public Service () {}

[WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public string HelloWorld() {

List<clsDetails> deailsList = new List<clsDetails>{
new clsDetails(1,"BOY","SCHOOL"),
new clsDetails(2,"GIRL","COLLEGE"),
new clsDetails(3,"MAN","OFFICE")};

string detail = serializer.Serialize(deailsList);
return detail;
}
}

如果我将 html 文件与我的网络服务一起托管,它会为我提供结果。但是当我尝试使用来自 Android 应用程序的本地 html 文件进行调用时,它失败了。我不知道出了什么问题。

谁能告诉我这里出了什么问题?看这里是我从网络服务获得的响应,我将其解析为 JSON

HTML HOSTED ALONG WITH WEBSERVICE

phonegap.xml

<phonegap>  
<access origin="http://182.72.192.18" />
</phonegap>

最佳答案

您必须使用本地 html 并使用 XHR 调用您的网络服务获取服务器数据,然后在您的 html 中显示您的网络服务的数据。

看到代码后编辑:

问题是网址。你不能使用localhost,因为如果你在一个设备上测试,localhost就是这个设备,而这个设备没有webservice,你必须使用你机器的本地iP。 http://192.168.1.XXX:1000/WebSite2/Service.asmx/HelloWorld

编辑 2:我刚刚测试了您的代码并让它为我工作,只需更改它即可。jsonArray[i].Result 对我不起作用,它返回未定义,但您可以访问 json 对象的每个属性,在示例中我使用了名称。并且把刷新放在for外面,只需要刷新完就刷新,不用每次都刷新,把;放在最后。

for(i=0; i < jsonArray.length; i++)
{
$("#details").append('<li id="'+i+'" name="head" >'+jsonArray[i].name+'</li>' );

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

如果仍然不起作用,请检查您是否将域列入白名单 phonegap whitelist guide

完整的工作代码

<!DOCTYPE html>
<html>
<head>
<title>DEMO</title>
<link rel="stylesheet" href="http://code.jquery.com/mobile/1.2.0/jquery.mobile-1.2.0.min.css" />
<script src="http://code.jquery.com/jquery-1.8.2.min.js"></script>
<script src="http://code.jquery.com/mobile/1.2.0/jquery.mobile-1.2.0.min.js"></script>
<title>DEMO</title>
<script type="text/javascript" charset="utf-8">

function LoginButton_onclick() {
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8",
dataType: "json",
url: "http://182.72.192.18/webservicedemo/service.asmx/HelloWorld",
data: '{}',
success: function(msg) {
jsonArray = $.parseJSON(msg.d);
var $ul = $( '<ul id="details">' );
for(i=0; i < jsonArray.length; i++)
{
$("#details").append('<li id="'+i+'" name="head" >'+jsonArray[i].name+'</li>' );
}
$('#details').listview('refresh');
},
error: function(msg) {
alert("Error");
}
});

}


</script>
</head>
<body>
<div data-role="page" id="Page1">
<h1>DEMO PAGE</h1>

<div id="DEMO">
<input id="LoginButton" type="button" value="GET DATA" onclick="LoginButton_onclick()" /></div>

<div id="divList" data-role="content">
<ul id="details" data-role="listview" data-inset="true"></ul>
</div>

</div>
</body>
</html>

关于javascript - Phonegap、jQueryMobile 和 Web 服务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13323747/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com