无法从资产路径在 phonegap 项目中使用 jquery 加载 xml 文件

Posted

技术标签:

【中文标题】无法从资产路径在 phonegap 项目中使用 jquery 加载 xml 文件【英文标题】:Unable to load xml file with jquery in phonegap project from assets path 【发布时间】:2012-09-14 06:27:36 【问题描述】:

我在 phonegap 项目中通过jQuery 移动从assets 路径加载xml 文件时遇到了很大的问题。

我需要加载一个xml 文件。文件放在我项目的 root 中。问题在于 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 的正确路径。

是否可以通过 jQuery 绝对/相对链接 URL 路径以便能够在 Android/ios 设备中加载文件?

更新 上面的代码是正确的。失败是在桌面浏览器中进行测试。项目在具有相对路径的 Android 和 iOS 上运行良好。

不需要添加绝对路径,如 Android 的 file:///android_asset/www/ 或 iOS 的 file:///var/mobile/Applications/7D6D107B-D9DC-479B-9E22-4847F0CA0C40/YourApplication.app/www/

【问题讨论】:

您是文件夹www 中的HTML 文件吗?如果是,您是否尝试使用url: "./language.xml"(附加./)而不是url: "language.xml" @Petr Latal,如果您找到了解决方案,请考虑发布您自己问题的答案 【参考方案1】:

查询:

    $("#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');
   

【讨论】:

【参考方案2】:

尝试将您的 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()
  ;
 );

希望它会起作用。

【讨论】:

以上是关于无法从资产路径在 phonegap 项目中使用 jquery 加载 xml 文件的主要内容,如果未能解决你的问题,请参考以下文章

Phonegap - 资产和通用 iOS 应用程序

无法加载 phonegap 地理定位插件。将.jar 添加到类路径?

从 Visual Studio IDE 运行时,项目无法加载图像资产

对phonegap和IOS感到困惑,需要从“插件”文件夹中的“www”路径获取文件

Android项目无法解析任何静态资产

从项目导入时,Xcode 图像资产目录无法看到所有图像?