如何从JSON数据获得价值到输入
我尝试使用jQuery AutoComplete从JSON数据获得价值。但是看来我的代码不起作用。我想要当我键入它显示的省份时,然后选择省名时也将获得ID,然后放入Province_ID的输入值。
查看代码:
<input type="text" id="province" name="province" id="province" class="form-control col-md-10"
placeholder="Province Name" />
<input type="hidden" name="province_id" id="province_id" class="form-control>
自动完成:
$(document).ready(function() {
var data = <?php echo json_encode($results); ?>;
$("#province").autocomplete({
source: data,
select: function(event, ui){
$('[name="province"]').val(ui.item.province);
$('[name="province_id"]').val(ui.item.province_id)
}
});
var数据:
[{"province_id":"1","province":"Bali"},{"province_id":"2","province":"Bangka Belitung"},{"province_id":"3","province":"Banten"},{"province_id":"4","province":"Bengkulu"},{"province_id":"5","province":"DI Yogyakarta"},{"province_id":"6","province":"DKI Jakarta"},{"province_id":"7","province":"Gorontalo"},{"province_id":"8","province":"Jambi"},{"province_id":"9","province":"Jawa Barat"},{"province_id":"10","province":"Jawa Tengah"},{"province_id":"11","province":"Jawa Timur"},{"province_id":"12","province":"Kalimantan Barat"},{"province_id":"13","province":"Kalimantan Selatan"},{"province_id":"14","province":"Kalimantan Tengah"},{"province_id":"15","province":"Kalimantan Timur"},{"province_id":"16","province":"Kalimantan Utara"},{"province_id":"17","province":"Kepulauan Riau"},{"province_id":"18","province":"Lampung"},{"province_id":"19","province":"Maluku"},{"province_id":"20","province":"Maluku Utara"},{"province_id":"21","province":"Nanggroe Aceh Darussalam (NAD)"},{"province_id":"22","province":"Nusa Tenggara Barat (NTB)"},{"province_id":"23","province":"Nusa Tenggara Timur (NTT)"},{"province_id":"24","province":"Papua"},{"province_id":"25","province":"Papua Barat"},{"province_id":"26","province":"Riau"},{"province_id":"27","province":"Sulawesi Barat"},{"province_id":"28","province":"Sulawesi Selatan"},{"province_id":"29","province":"Sulawesi Tengah"},{"province_id":"30","province":"Sulawesi Tenggara"},{"province_id":"31","province":"Sulawesi Utara"},{"province_id":"32","province":"Sumatera Barat"},{"province_id":"33","province":"Sumatera Selatan"},{"province_id":"34","province":"Sumatera Utara"}];
任何帮助将不胜感激,谢谢。
I tried to get value from JSON data to my input using jquery autocomplete. But it seems my code isn't working. I want when I type the province name it shows up then when I select the province name will also get the id and then put in the input value for province_id.
view code:
<input type="text" id="province" name="province" id="province" class="form-control col-md-10"
placeholder="Province Name" />
<input type="hidden" name="province_id" id="province_id" class="form-control>
autocomplete :
$(document).ready(function() {
var data = <?php echo json_encode($results); ?>;
$("#province").autocomplete({
source: data,
select: function(event, ui){
$('[name="province"]').val(ui.item.province);
$('[name="province_id"]').val(ui.item.province_id)
}
});
var data :
[{"province_id":"1","province":"Bali"},{"province_id":"2","province":"Bangka Belitung"},{"province_id":"3","province":"Banten"},{"province_id":"4","province":"Bengkulu"},{"province_id":"5","province":"DI Yogyakarta"},{"province_id":"6","province":"DKI Jakarta"},{"province_id":"7","province":"Gorontalo"},{"province_id":"8","province":"Jambi"},{"province_id":"9","province":"Jawa Barat"},{"province_id":"10","province":"Jawa Tengah"},{"province_id":"11","province":"Jawa Timur"},{"province_id":"12","province":"Kalimantan Barat"},{"province_id":"13","province":"Kalimantan Selatan"},{"province_id":"14","province":"Kalimantan Tengah"},{"province_id":"15","province":"Kalimantan Timur"},{"province_id":"16","province":"Kalimantan Utara"},{"province_id":"17","province":"Kepulauan Riau"},{"province_id":"18","province":"Lampung"},{"province_id":"19","province":"Maluku"},{"province_id":"20","province":"Maluku Utara"},{"province_id":"21","province":"Nanggroe Aceh Darussalam (NAD)"},{"province_id":"22","province":"Nusa Tenggara Barat (NTB)"},{"province_id":"23","province":"Nusa Tenggara Timur (NTT)"},{"province_id":"24","province":"Papua"},{"province_id":"25","province":"Papua Barat"},{"province_id":"26","province":"Riau"},{"province_id":"27","province":"Sulawesi Barat"},{"province_id":"28","province":"Sulawesi Selatan"},{"province_id":"29","province":"Sulawesi Tengah"},{"province_id":"30","province":"Sulawesi Tenggara"},{"province_id":"31","province":"Sulawesi Utara"},{"province_id":"32","province":"Sumatera Barat"},{"province_id":"33","province":"Sumatera Selatan"},{"province_id":"34","province":"Sumatera Utara"}];
any help would be greatly appreciated, thank you.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
jQueryui自动完成
源
属性仅接受特定格式的数据。它必须是至少标签
和value
属性的对象数组。您需要修改data
变量以此格式。我建议您在来自PHP的
$结果
变量中进行此操作,但是如果无法实现,则可以使用map()
数组的方法。请注意,您需要更新由于此更改而用于设置字段值的ui.item
的属性。最后,请注意,我已经使用
id
选择该字段的选择器,因为元素已经存在,并且比属性选择器更简单,更快。The jQueryUI autocomplete
source
property only accepts data in a specific format. It needs to be an array of objects with at leastlabel
andvalue
properties. You need to amend yourdata
variable to be in this format.I would suggest doing this in your
$results
variable coming from PHP, however if it's not possible to achieve then you can use themap()
method of the array instead. Note that you need to update the properties ofui.item
that you use to set the field values because of this change.Finally, note that I used
id
selectors for the fields as there are present on the elements already, and simpler and faster than attribute selectors.