【发布时间】:2011-01-29 13:49:20
【问题描述】:
我必须遗漏一些简单的东西,但我真的不确定是什么。
我有一个按钮,单击该按钮会获取 JSON 数据。当下拉列表被更改时,我检查是否有数据,如果有,我想将其清除,因为下拉列表指示单击按钮时要检索的数据
代码:
var selected, $locDialog;
var locations = [];
$(function() {
// Save the selected Name
selected = $("#selected option:selected").val();
// Setup Dialog for Locations
$locDialog = $('#location-dialog').dialog({
autoOpen: false
});
// If user changes the selected
// 1. Prompt for confirmation
// 2. If users confirms, clear data
$('#selected').change(function() {
if (locations) {
var confirmed = confirm("Oh Rly?");
if (confirmed) {
// Clear data
var locations;
}
}
});
// When user clicks "Location" Button..
$('.loc-select button').click(function() {
if (!locations) {
$.getJSON("/Controller/JSONAction", { selectedId: selected, pageNum: 1, pageSize: 100 }, function(data) {
locations = data;
$.each(locations, function(index, loc) {
var $tr = $('<tr/>')
.append($('<td/>')
.append('<input type="checkbox" name="TEST-'+index+'" value="'+loc.Id+'"/>'))
.append('<td>' + loc.Name + '</td>');
$("#location-dialog table tbody").append($tr);
});
});
}
$locDialog.dialog('open');
return false;
});
});
事情是这样的,在.click(...) 回调中,我可以看到locations 是[]。现在,当我在.change(...) 回调中时,我看到locations 是undefined。
【问题讨论】:
标签: javascript jquery global-variables scope