您好我正在使用jquery和ajax从CMS API发布和获取数据。我正在生成一个查询字符串来获取数据:
region = typeof region !== 'undefined' ? 'region='+region : '';
centre = typeof centre !== 'undefined' ? 'centre='+centre : '';
data = region+centre; // generate query string
现在我认为如果未定义,上面的内容将不会传递任何内容,但如果我在单击触发中心变量的按钮时调度日志data
,则会传递region="undefined"centre="Centre Market"
。但是我希望它只是传递centre="Centre Market"
,这将是点击按钮的href。
这是我的点击功能:
$('ul.dropdown li a').click(function (e) {
e.preventDefault();
console.info('Selected Centre: "' + $(this).attr('href') + '"');
var centre = $(this).attr('href');
getData.update('/overview', 'undefined' centre);
});
如您所见,这会将href
属性传递给getData.update函数,此函数位于...
var getData = {
update: function (url, region, centre) {
region = typeof region !== 'undefined' ? 'region='+region : '';
centre = typeof centre !== 'undefined' ? 'centre='+centre : '';
// i dont want to pass region if it is undefined
data = region+centre; // generate query string
console.log(data);
$.ajax({
url: url,
async: true,
dataType: 'json',
data: data, // data passed here
type: 'POST',
success: function (json) {
//success stuff....
}
});
}
}
如您所见,我将数据传递到ajax函数中:
data = region+centre; // generate query string
因此,如果区域未定义或为空或未通过,我不希望这是查询字符串的一部分,即不包括region=
。我有什么想法可以做到这一点吗?
答案 0 :(得分:0)
检查是否为null,并添加字符串检查(您可以检查typeof string):
$('ul.dropdown li a').click(function (e) {
e.preventDefault();
console.info('Selected Centre: "' + $(this).attr('href') + '"');
var centre = $(this).attr('href');
getData.update('/overview', null, centre);
});
如您所见,这会将href属性传递给getData.update函数,此函数位于...
var getData = {
update: function (url, region, centre) {
region = (region != null && typeof region == 'string') ? 'region='+region : '';
centre = typeof centre !== 'undefined' ? 'centre='+centre : '';
// i dont want to pass region if it is undefined
data = region+centre; // generate query string
console.log(data);
$.ajax({
url: url,
async: true,
dataType: 'json',
data: data, // data passed here
type: 'POST',
success: function (json) {
//success stuff....
}
});
}
}