替a标签添加动态的请求参数
为a标签添加动态的请求参数
前言:通常情况下,我们《为a标签添加动态的请求参数》显得没有必要,因为a标签提供了href属性给我们,以来请求某一个资源,我们也可以在url中添加静态的参数,如<a href="love/you?name=xiaofang"/>
,然而也有一些时候,我们不想一直使用form传递,我们也不想为每一个请求写ajax请求,那么这个时候我们怎么做呢?
代码
<a href="${ctx}/project/initPublishProduct?callbackType=forward&tabIndex=1" target="ajaxTodo" data="tabIndex" callback="ajaxDone" style="width: 100px;" class="btn btn-default">下一步</a>
我们为其增加一个data属性,其data值指定为某一个元素id。
<input type="hidden" id="tabIndex" value="${tabIndex}">
tabIndex可动态变化。
然后我们该怎么把tabIndex封装到a标签的请求参数中呢?
$.fn.extend({
ajaxTodo : function() {
return this.each(function() {
var $this = $(this);
$this.click(function(event) {
var url = unescape($this.attr("href")).replaceTmById($(event.target).parents(".unitBox:first"));
YUNM.debug(url);
if (!url.isFinishedTm()) {
$.showErr($this.attr("warn"));
return false;
}
var dataId = $this.attr("data");
if (dataId) {
if (dataId.indexOf(",") != -1) {
$.each(dataId.split(","), function(index, id){
if ($("#" + id) && $("#" + id).val()) {
addMoreParamForUrl(url, id, $("#" + id).val());
}
});
} else {
if ($("#" + dataId) && $("#" + dataId).val()) {
addMoreParamForUrl(url, dataId, $("#" + dataId).val());
}
}
}
var title = $this.attr("atitle");
if (title) {
$.showConfirm(title, function() {
ajaxTodo(url, $this.attr("callback"));
});
} else {
ajaxTodo(url, $this.attr("callback"));
}
event.preventDefault();
});
});
},
});
我们先从a标签中获取data值,然后,根据data的值,获取隐藏域,然后再取隐藏域的值,封装到url中。
function addMoreParamForUrl(url, key, value) {
if (url.indexOf("?") != -1) {
url += "&" + key + "=" + value;
} else {
url += "?" + key + "=" + value;
}
return url;
}
如此,我们就可以很灵活的使用a标签了。
版权声明:本站博客均为qing_gee原创文章,若您需要引用、转载,只需要注明来源及原文链接即可。