我搜索了论坛,但没有找到任何问题的答案。
我正在使用jquery自动填充来填充表单字段。
我目前正在使用XML文件中的本地数据(下面的代码第一部分)。 这对于本地查询所需的答案非常有用,但如果本地XML不包含正确的查询结果,我希望有一个备用数据源(JSON geoname - 请参阅下面的代码第二部分)。
我尝试了并且未能合并这两个数据源,所以为了简单起见,我在这里单独发布它们。
它们都独立工作 - 但如何将它们合并到一个结果字段中? 此外,XML数据应该是主要选择。
CODE PART ONE
XML本地源代码
$(document).ready(function() {
var myArr = [];
$.ajax({
type: "GET",
url: "airports.xml",
dataType: "xml",
success: parseXml,
complete: setupAC,
failure: function(data) {
alert("XML File could not be found");
}
});
function parseXml(xml)
{
//find every query value
$(xml).find("state").each(function()
{
//you are going to create an array of objects
var thisItem = {};
thisItem['label'] = $(this).attr("label") + ', ' + $(this).attr("country");
thisItem['value'] = $(this).attr("iata");
myArr.push(thisItem);
});
}
function setupAC() {
$("#city").autocomplete({
source: myArr,
minLength: 3,
select: function(event, ui) {
$("#city").val(ui.item.iata);
$("#qf").submit();
}
});
}
});
代码第一部分airports.xml文件摘要
<states>
<state label="London Heathrow" iata="LHR" country="UK" />
<state label="Syndey" iata="SYD" country="Australia" />
...
代码第一部分搜索表单摘录
<label for="city">From</label></td>
代码第二部分 以下是使用geonames中的JSON自动完成的代码
$(function() {
function log( message ) {
$( "<div/>" ).text( message ).prependTo( "#log" );
$( "#log" ).attr( "scrollTop", 0 );
}
$( "#city" ).autocomplete({
source: function( request, response ) {
$.ajax({
url: "http://ws.geonames.org/searchJSON",
dataType: "jsonp",
data: {
featureClass: "P",
style: "full",
maxRows: 20,
name_startsWith: request.term
},
success: function( data ) {
response( $.map( data.geonames, function( item ) {
return {
label: item.name + (item.adminName1 ? ", " + item.adminName1 : "") + ", " + item.countryName,
value: item.name
}
}));
}
});
},
minLength: 2,
select: function( event, ui ) {
log( ui.item ?
"Selected: " + ui.item.label :
"Nothing selected, input was " + this.value);
},
open: function() {
$( this ).removeClass( "ui-corner-all" ).addClass( "ui-corner-top" );
},
close: function() {
$( this ).removeClass( "ui-corner-top" ).addClass( "ui-corner-all" );
}
});
});
答案 0 :(得分:1)
我认为你可以合并这两个数据集,特别是将json调用的结果与从excel中获取的数据合并。我就是这样做的(我没有使用excel中的数据,但是静态数据,但它应该是相同的);
var availableTags = [];
var london = { label: 'London Airport - UK', value: 'LHR'};
var paris= { label: 'Paris Airport - FRA', value: 'PAR'};
availableTags.push(london);
availableTags.push(paris);
$("#city2").autocomplete({
source: availableTags
});
function log( message ) {
$( "<div/>" ).text( message ).prependTo( "#log" );
$( "#log" ).attr( "scrollTop", 0 );
}
function filterArrayForString(string, array){
var results = [];
$.each(array, function(i, el){
var label= el.label;
if (label.toLowerCase().indexOf(string.toLowerCase()) !== -1){
results.push(el);
}
});
return results;
}
$( "#city" ).autocomplete({
source: function( request, response ) {
$.ajax({
url: "http://ws.geonames.org/searchJSON",
dataType: "jsonp",
data: {
featureClass: "P",
style: "full",
maxRows: 20,
name_startsWith: request.term
},
success: function( data ) {
var dataConv = $.map( data.geonames, function( item ) {
return {
label: item.name + (item.adminName1 ? ", " + item.adminName1 : "") + ", " + item.countryName,
value: item.name
}
});
var filteredAvailable = filterArrayForString(request.term, availableTags );
console.log(request.term);
console.log(filteredAvailable);
var both = filteredAvailable.concat(dataConv);
response(both);
}
});
},
minLength: 2,
select: function( event, ui ) {
log( ui.item ?
"Selected: " + ui.item.label :
"Nothing selected, input was " + this.value);
},
open: function() {
$( this ).removeClass( "ui-corner-all" ).addClass( "ui-corner-top" );
},
close: function() {
$( this ).removeClass( "ui-corner-top" ).addClass( "ui-corner-all" );
}
});
合并的数据位于both
变量中,您甚至可以对其进行排序以获得更好的结果。在这里小提琴:http://jsfiddle.net/7cLxD/7/(在jsonP输入中写一下,你将作为伦敦从静态数组中取得的第一个结果)