以下代码在PHP中。我想在Java中做同样的事情。请告诉我如何在Java中生成这种类型的数组或集合。我需要这个来响应JSON自动完成。
<?php
$q = strtolower($_GET["q"]);
if (!$q) return;
$items = array(
"Peter Pan"=>"peter@pan.de",
"Molly"=>"molly@yahoo.com",
"Forneria Marconi"=>"live@japan.jp",
"Master Sync"=>"205bw@samsung.com",
"Dr. Tech de Log"=>"g15@logitech.com",
"Don Corleone"=>"don@vegas.com",
"Mc Chick"=>"info@donalds.org",
"Donnie Darko"=>"dd@timeshift.info",
"Quake The Net"=>"webmaster@quakenet.org",
"Dr. Write"=>"write@writable.com"
);
$result = array();
foreach ($items as $key=>$value) {
if (strpos(strtolower($key), $q) !== false) {
array_push($result, array(
"name" => $key,
"to" => $value
));
}
}
echo json_encode($result);
?>
我想要这个PHP代码的java版本,因为此代码以JSON格式返回。在
{name=>"Peter Pan",
to=>"peter@pan.de";
.....}
如你所见: -
array_push($result, array(
"name" => $key,
"to" => $value
));
这个jQuery代码可以处理: -
$('#inputItem').autocomplete('<c:url value="/json/itemautocomplete.do" />', {
multiple: true,
mustMatch: true,
autoFill: true,
highlight: false,
scroll: true,
dataType: "json",
parse: function(data){
var array = new Array();
for(var i = 0; i<data.length; i++){
array[array.length] = {data: data[i], value: data[i].name, result: data[i].name};
}
return array;
}
});
此插件位于this url
我知道如何在JSONArray
jQuery方法中使用$.getJSON
来处理JSON数据。但在这种情况下,那件事情不起作用。我想我需要按照上面在本答案中描述的那样格式化我的数据,以便这个jQuery自动完成插件可以理解数据。请告诉我怎样才能得到这个......
答案 0 :(得分:1)
在Java中,您将使用Map<String, String>
:
Map<String, String> items = new HashMap<String, String>();
items.put("Peter Pan", "peter@pan.de");
String petersAddress = items.get("Peter Pan");
您可以遍历密钥集:
for ( String key : items.keySet() ) {
if ( key.toLowerCase().startsWith(input) ) {
//add to list of potential matches
}
}
答案 1 :(得分:0)
感谢您的支持。
我已使用此代码处理数据: - 在Servlet中: -
LinkedList arr = new LinkedList();
arr.add("Peter Pan <peter@pan.de>");
arr.add("Molly <molly@yahoo.com>");
arr.add("Forneria Marconi <live@japan.jp>");
Iterator iter = arr.iterator();
while(iter.hasNext()){
out.println(iter.next());
}
在JQuery中: -
function itemAutocomplete(){
$('#inputItem').autocomplete('<c:url value="/json/itemautocomplete.do?mi=' + $('#sltMainItem').val() + '&si=' + $('#sltSubItem').val() + '" />', {
json: true
});
}
感谢您的光临 沙姆斯