我在phonegap项目中通过xml
mobile从assets
路径加载jQuery
文件时遇到了很大的问题。
我需要加载一个xml
文件。文件放置在我项目的根中。问题出在ajax网址上:“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 Assets 。但是我也需要 iOS的正确路径。是否可以通过jQuery绝对/相对地链接URL路径,以便能够在Android/iOS设备中加载文件?
更新
上面的代码是正确的。在桌面浏览器中进行测试失败。在具有相对路径的Android和iOS上,Project可以正常工作。
不需要来添加绝对路径,例如Android的
file:///android_asset/www/
或iOS的file:///var/mobile/Applications/7D6D107B-D9DC-479B-9E22-4847F0CA0C40/YourApplication.app/www/
。 最佳答案
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');
}
关于android - 无法从 Assets 路径在phonegap项目中使用jQuery加载xml文件,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/12537186/