Ho creato un'applicazione Android nativa utilizzando i pacchetti Android SDK e java, utilizzando un servizio Web ASP.Net creato da me e funziona perfettamente. Ma ora voglio fare questo multipiattaforma. Ho sentito che Phonegap e jQuery Mobile ti aiuteranno, ma sono ancora un po 'confuso.PhoneGap, jQueryMobile e servizio Web
- È necessario ospitare il file HTML che utilizza Javascript per funzionare correttamente? O
- Posso includere il file HTML e js nella mia applicazione e chiamare i metodi del servizio web?
Qualcuno può guidarmi per favore?
mio codice Demo è
JAVA SCRIPT
<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>
e la mia ASP.NET Web Service è
[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;
}
}
se ospito il file html insieme al mio servizio web mi fornisce risultato. ma quando provo a chiamare usando un file html locale dall'app per Android fallisce. Non riesco a capire cosa è andato storto.
Qualcuno può dirmi cosa è andato storto qui? Guardate qui è la risposta che ricevo da web-service e il parsing che a JSON
phonegap.xml
<phonegap>
<access origin="http://182.72.192.18" />
</phonegap>
Hai guardato il sito web di PhoneGap? È abbastanza ben documentato. – jiggy
@jiggy I non significa che sia un sito Web. Sto chiedendo che è possibile utilizzare il servizio telefonico per chiamare servizi web dinamici. qual è il modo per farlo? – edwin
Intendevo andare su [phonegap.com] (http://phonegap.com/developer) e leggere i documenti prima di fare domande davvero basilari. Prova a cercare su google le tue domande prima di pubblicare. – jiggy