在查询字符串中重复变量

时间:2013-01-30 23:29:02

标签: javascript jquery html firefox

我遇到了javascript和firefox 10.0.11的奇怪问题。我已经使用IE测试过,无法复制该问题。

我有一个链接转到显示有关对象的一些信息的页面。我已使用javascript为此页面添加了其他功能。如果启用了javascript,则锚链接将被重定向到javascript函数。

<a href="/Comment?id=1186281" onclick="return CommentSubmit(1186281)">Comment</a>
function CommentSubmit(id) {
    $("#DynForm").append("<input type='hidden' name='id' value='" + id + "' />");
    $("#DynForm").attr("action", "/Comment/Index");
    $("#DynForm").submit();
    return false;
};

如您所见,javascript会插入带有键值的隐藏输入标记。无javascript版本工作正常,但我遇到一些与JavaScript的问题。当第一次点击任何项目的Comment按钮时,它会罚款。如果我回击然后点击任意Comment链接,该页面就会显示,就像我再次点击了第一个链接一样。检查后,我注意到每个后续“后退”和“点击”

的url参数都会“堆叠”
/Comment?id=1
/Comment?id=1&id=2
/Comment?id=1&id=2&id=3

如果我再次导航到该页面(不返回),第一个链接将再次起作用然后启动这个奇怪的行为。单击几个链接后查看页面源,我看到没有新的hidden字段会添加这些附加参数。这是一个已知的问题?如何进一步调试并修复它?

1 个答案:

答案 0 :(得分:6)

这不是错误,它是一个功能:)

您的浏览器正在缓存该页面,因此当您返回时不会刷新它,您将返回原来的状态,即使用隐藏的输入字段。

您需要做的就是在再次追加该字段之前删除该字段。

function CommentSubmit(id) {
    $("input[name=id]").remove();
    $("#DynForm").append("<input type='hidden' name='id' value='" + id + "' />");
    $("#DynForm").attr("action", "/Comment/Index");
    $("#DynForm").submit();
    return false;
};