关于使用 AJAX 或更具体地说,jQuery 的 $get 函数设置选择选项的选定值,我遇到了这个问题。我似乎无法让它工作。设置文本框工作正常,但我不明白为什么设置选择选项不起作用。
$(document).ready(function() {
$youth_id = $('#youth_id').attr('id');
$.get("./php-scripts/json-get-youth-details.php", { youth_id: $youth_id },
function(data) {
$('input[name="lastname"]').val(data.lastname);
$('select[name="cellgroup_id"]').val(data.cellgroup_id);
}, "json");
});
我认为问题在于加载顺序。我认为 jQuery 甚至在正文部分中的 PHP 脚本加载之前加载。我不明白,因为 jQuery 脚本位于 body 标记下方,因此即使在加载脚本之前也必须加载 body。
我尝试删除要在 $(document).ready 脚本之后加载的其他脚本(请参见下面的代码),令人惊讶的是,它可以正常工作。但是,我无法删除这些脚本,因为我需要它们,并且我不能将它们放在前面,因为 UI 标记将被更改(因为引导程序)。哦,我在其他地方找不到解决方案!
<script src="./js/jquery.js"></script>
<script src="./js/jquery-ui-1.10.0.custom.min.js"></script>
<script>
// Insert $(document).ready script here
</script>
<script src="./js/jquery.tagsinput.js"></script>
<script src="./js/bootstrap-tooltip.js"></script>
<script src="./js/jquery.placeholder.js"></script>
<script src="http://vjs.zencdn.net/c/video.js"></script>
<script src="./js/application.js"></script>
<script src="./js/jquery.dropkick-1.0.0.js"></script>
这是加载选择选项的代码:
<select class="span3" tabindex="0" name="cellgroup_id">
<option value="NULL">N/A</option>
<?php
$cellgroupOptions = "";
include_once("./classes/cellgroup.php");
$cellgroup = new CellGroup();
$cellgroupList = $cellgroup->getCellGroupList();
foreach( $cellgroupList as $cellgroupDetail )
{
$cellgroup_id = $cellgroupDetail['cellgroup_id'];
$cellgroup_name = $cellgroupDetail['cellgroup_name'];
$cellgroupOptions .=<<<EOT
<option value="$cellgroup_id">$cellgroup_name</option>
EOT;
}
echo $cellgroupOptions;
?>
</select>
根据要求,下面是加载脚本(PHP 和 Bootstrap)后 HTML 中选择的输出。Bootstrap 脚本在 HTML 中发生了很大变化。
<div class="dk_container span3 dk_shown dk_theme_default" id="dk_container_cellgroup_id" tabindex="0">
<a class="dk_toggle">
<span class="dk_label">N/A</span>
<span class="select-icon"></span>
</a>
<div class="dk_options">
<ul class="dk_options_inner">
<li class="dk_option_current"><a data-dk-dropdown-value="NULL">N/A</a></li>
<li class=""><a data-dk-dropdown-value="1">Arrows of God</a></li>
<li class=""><a data-dk-dropdown-value="2">Fishmen</a></li></ul></div></div>
</ul></div>
</div>
</div>