Не удалось загрузить файл xml с jquery в проекте phonegap из пути к ресурсам

У меня есть огромная проблема с загрузкой xml файла из пути к assets jQuery mobile в проекте phonegap.

Мне нужно загрузить файл xml . Файл помещается в корень моего проекта. Проблема заключается в ajax url: "language.xml" . Вот мой код:

 var language = 'english'; var regEx = /(\w+([-+.']\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*)/; $.ajax({ url: "language.xml", success: function(xml) { $(xml).find('translation').each(function(){ var id = $(this).attr('id'); var text = $(this).find(language).text(); if(text.match(regEx)){ $("." + id).replaceWith('<a href="mailto:'+text+'" data-role="button" data-inline="true" data-theme="d" rel="external" data-mini="true">'+text+'</a>'); } else{ $("." + id).html(text); } }); } }); 

Когда я использую абсолютный путь, я могу загрузить этот файл, добавив url: file:///android_asset/www/language.xml

Это полезно только для Android-активов. Но мне нужен правильный путь для iOS .

Можно ли связать URL-адрес абсолютным / релятивным с помощью jQuery, чтобы иметь возможность загружать файл на устройствах Android / iOS?

Код UPDATE указан правильно. Ошибка в тестировании в настольном браузере. Проект отлично работает на Android и iOS с относительными путями.

Нет необходимости добавлять абсолютный путь, например file:///android_asset/www/ для Android или file:///var/mobile/Applications/7D6D107B-D9DC-479B-9E22-4847F0CA0C40/YourApplication.app/www/ для iOS.

Solutions Collecting From Web of "Не удалось загрузить файл xml с jquery в проекте phonegap из пути к ресурсам"

Jquery:

  $("#inputString").live("keyup", function(e) { $.post("FILE.PHP",{ char:$("#inputString").val() }, function(data){},'json'); }); 

PHP-код:

 <?php $sql = "SELECT `name` FROM `list` WHERE `name` LIKE '%{$_POST['queryString']}%'"; $query=mysql_query($sql); if($result) { foreach ($result as $value) echo '<li onClick="fill(\''.$value['name'].'\');">'.$value['name'].'</li>'; } } ?> 

CSS:

 #autoSuggestionsList { position: absolute; margin: 30px 4px; width: 175px; padding: 0; font-size: 11px; color: #000; border-radius: 5px; background: #c3d9ff; /* Old browsers */ background: -moz-linear-gradient(top, #c3d9ff 0%, #b1c8ef 41%, #98b0d9 100%); /* FF3.6+ */ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#c3d9ff), color-stop(41%,#b1c8ef), color-stop(100%,#98b0d9)); /* Chrome,Safari4+ */ background: -webkit-linear-gradient(top, #c3d9ff 0%,#b1c8ef 41%,#98b0d9 100%); /* Chrome10+,Safari5.1+ */ background: -o-linear-gradient(top, #c3d9ff 0%,#b1c8ef 41%,#98b0d9 100%); /* Opera 11.10+ */ background: -ms-linear-gradient(top, #c3d9ff 0%,#b1c8ef 41%,#98b0d9 100%); /* IE10+ */ background: linear-gradient(to bottom, #c3d9ff 0%,#b1c8ef 41%,#98b0d9 100%); /* W3C */ filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c3d9ff', endColorstr='#98b0d9',GradientType=0 ); /* IE6-9 */ } .suggestionList { margin: 0px; padding: 0px; } .suggestionList li { list-style: none; direction: rtl; text-align: right; margin: 0px 0px 0px 0px; padding: 3px; cursor: pointer; } .suggestionList li:hover { background-color: #659CD8; color: #fff; } #autoSuggestionsList li:first-child { border-top-left-radius: 5px; border-top-right-radius: 5px; border-radius: 5px 5px 0px 0px; behavior: url('./css/PIE.htc'); } #autoSuggestionsList li:last-child { border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; border-radius: 0px 0px 5px 5px; behavior: url('./css/PIE.htc'); } 

Попробуйте поместить ваш XML-файл в папку «www», а затем вы сможете получить доступ к файлу только с именем файла.

Также см. Пример автозаполнения: http://jqueryui.com/autocomplete/#xml В демоверсии они напрямую обратились к "london.xml"

 $.ajax({ url: "london.xml", dataType: "xml", success: function( xmlResponse ) { var data = $( "geoname", xmlResponse ).map(function() { //alert($('name', this).text()); return { value: $( "name", this ).text() + ", " + ( $.trim( $( "countryName", this ).text() ) || "(unknown country)" ), id: $( "geonameId", this ).text() }; }); 

Надеюсь, это сработает.