提交表单值而不加载新页面

时间:2013-05-04 16:29:10

标签: php

我有一个表单,用于将值传递给另一个页面及其工作。

在没有打开我的表单操作设置的页面的情况下,有没有这样做?

我认为可以使用ajax和javascript

完成
echo "<form name=\"android\"  method=\"post\" action=\"http://www.example.com\" target=\"_blank\">";
echo "<input type=\"hidden\" name=\"appid\" value=\"$appid\" />";
echo "<input type=\"hidden\" name=\"pushmessage\" value=\"$pushmessage\" />";
echo "<input type=\"hidden\" name=\"username\" value=\"$user\" />";
echo "<input type=\"hidden\" name=\"pass\" value=\"$pass\" />";
echo  "<input type=\"hidden\" name=\"publisherid\" value=\"createcoolapps\" />";
//echo "<input type=\"submit\" value=\"Push\" name=\"sub\" />";
echo "</form>";
echo "<script> document.forms[0].submit();</script>";

3 个答案:

答案 0 :(得分:1)

试试这个:

$url = 'http://www.example.com/';
$fields = array(
    'appid' => urlencode($appid),
    'pushmessage' => urlencode($pushmessage),
    'username' => urlencode($user),
    'pass' => urlencode($institution),
    'publisherid' => urlencode("createcoolapps")
);

foreach($fields as $key=>$value) { $fields_string .= $key.'='.$value.'&'; }
rtrim($fields_string, '&');

$ch = curl_init();

curl_setopt($ch,CURLOPT_URL, $url);
curl_setopt($ch,CURLOPT_POST, count($fields));
curl_setopt($ch,CURLOPT_POSTFIELDS, $fields_string);

$result = curl_exec($ch);

curl_close($ch);

答案 1 :(得分:0)

是的,正如您所想,这可以使用Ajax完成。到目前为止,最简单的方法是使用jQuery的AJAX库(因为如果没有别的,那么现在不使用jQuery)从这里开始:http://api.jquery.com/jQuery.ajax/

示例可能如下(未经测试,但有些正确):

<form action="mypage.php" method="post"> <!-- Args for when JS is disabled -->
    <input type="text" id="form_text_1" value="" />
    <input type="submit" id="form_submit" />
</form>

<script>
    $('#form_submit').click(function() {
        jquery.ajax("mypage.php", {
            type: "post",
            data: {
                text1: $('#form_text_1').val()
            }
        });
        return false; // Stop the form being submitted in the foreground when JS works
    });
</script>

当然,根据您的需要进行调整。

答案 2 :(得分:0)

如果您可以包含jQuery库,这非常简单:http://www.jquery.com

如果你使用jQuery和上面的代码,你可以执行以下操作:

$('input[name="sub"]').click( function() {
   $.post($(this).parents('form').attr('action'), $(this).parents('form).serialize());
   return false;
} );

这会拦截名为“sub”的提交的点击,然后执行和AJAX发布到表单的操作。

您最好查看浏览器控制台,以跟踪发布的数据并发现任何问题。