基本上我想做的是当我改变窗口时发送POST数据。位置,就好像用户提交了一个表单,然后它转到了一个新页面。我需要这样做,因为我需要传递一个隐藏的URL,我不能简单地将它作为一个GET放在URL中。
这是我目前拥有的,但它不发送任何POST数据。
if(user has not voted) {
window.location = 'http://example.com/vote/' + Username;
}
我知道你可以用jQuery.post()发送POST数据,但我需要它与新的window.location一起发送。
因此,概括一下,我需要通过POST将api_url值发送到http://example.com/vote/,同时将用户发送到同一页面。
为了便于将来参考,我最后做了以下工作:
if(user has not voted) {
$('#inset_form').html('<form action="http://example.com/vote/' + Username + '" name="vote" method="post" style="display:none;"><input type="text" name="api_url" value="' + Return_URL + '" /></form>');
document.forms['vote'].submit();
}
这里的答案可能令人困惑,所以我会给你一个示例代码,我正在工作。
首先请注意,java脚本windows没有POST参数。你所引用的定位函数。
所以你必须…
动态地创建带有POST参数的表单。
动态地放置一个或多个带有您想要发布的值的文本框
调用动态创建的提交表单。
举个例子。
//---------- make sure to link to your jQuery library ----//
<script type="text/javascript" >
var form = $(document.createElement('form'));
$(form).attr("action", "test2.php");
$(form).attr("method", "POST");
$(form).css("display", "none");
var input_employee_name = $("<input>")
.attr("type", "text")
.attr("name", "employee_name")
.val("Peter" );
$(form).append($(input_employee_name));
var input_salary = $("<input>")
.attr("type", "text")
.attr("name", "salary")
.val("1000" );
$(form).append($(input_salary));
form.appendTo( document.body );
$(form).submit();
</script>
如果一切顺利,您将被重定向到test2.php,您可以使用POST读取传递的employee_name和salary的值;分别是彼得和1000。
在test2.php中,您可以这样获取您的值。
$employee_name = $_POST['employee_name'];
$salary = $_POST['salary'];
不用说,一定要清除传递的值。
这里有一个简单的小函数,只要你使用jQuery,它就可以应用在任何地方。
var redirect = 'http://www.website.com/page?id=23231';
$.redirectPost(redirect, {x: 'example', y: 'abc'});
// jquery extend function
$.extend(
{
redirectPost: function(location, args)
{
var form = '';
$.each( args, function( key, value ) {
value = value.split('"').join('\"')
form += '<input type="hidden" name="'+key+'" value="'+value+'">';
});
$('<form action="' + location + '" method="POST">' + form + '</form>').appendTo($(document.body)).submit();
}
});