好的,我有一个jquery .post返回我需要的东西,但它输出不正确。
这是我的代码:
jQuery(document).ready(function($){
$('#project-for-support-ticket').change(function(){
//Pass The value selected to the get_users_from_project_id() function
var projectSelected = $(this).val();
if(projectSelected == 'NULL'){
$('#users-of-project').empty();
}
$.post( '/wp-admin/admin-ajax.php', { 'selectedProject' : projectSelected, 'action' : 'support_ticket_ajax'},
function(data) {
var newdata = jQuery.parseJSON( data );
var value = 'ID';
var text = 'name';
returnOptions(newdata, '#users-of-project', value, text);
}, "JSON"
);
})
$('#user-to-assign-project').change(function(){
var UserSelected = $(this).val();
if(UserSelected == 'none'){
$('#user-type-to-assign-as').empty();
}
$.post( '/wp-admin/admin-ajax.php', { 'UserSelected' : UserSelected, 'action' : 'assign_project_ajax'},
function(data) {
var newdata = jQuery.parseJSON( data );
var value = '';
var text = '';
returnOptions(newdata, '#user-type-to-assign-as', value, text);
}, "JSON"
);
})
function returnOptions(newdata, SelectToPopulate, value, text){
//Empty the select box so we are not simply adding more to it!
$(SelectToPopulate).empty();
//Run a for loop, the closest thing javascript easily has to a foreach loop
for ( var i in newdata ){
if(!(value == '')){
OptVal = newdata[i].value;
}else{
OptVal = newdata[i];
}
alert (OptVal);
if(!(text == '')){
OptText = newdata[i].text;
}else{
OptText = newdata[i];
}
//And Append an 'Option' to the select tag
$(SelectToPopulate).append($('<option></option>').attr('value', OptVal ).text(OptText));
}
}
})
问题在于returnOptions函数,用户到分配项目工作正常,但是对于支持项目的票证,当我提醒OptVal时,我得到'未定义',但是如果我提醒newData [i ] .name警告正确的值。
谁能看到我做错了什么?
干杯 本
答案 0 :(得分:0)
你似乎没有声明OptVal因此未定义。在函数中,returnOptions从以下行开始 var OptVal; 然后你应该能够毫无问题地提醒OptVal。