AJAX POST - how to use a js variable in PHP

后端 未结 3 1664
眼角桃花
眼角桃花 2021-01-28 18:48

The first time the page loads, there will not be anything in the POST data array. After it runs I want to be able to use whatever variable I send in the POST data in the PHP co

相关标签:
3条回答
  • 2021-01-28 19:26

    You can accomplish this by using an Ajax request. You have already loaded the JQuery library and have code that sends an Ajax request.

    Maybe you are looking for how to use the Ajax response on your client side script or how to send an Ajax request to the server on a client side event.

    Ajax is a way to communicate with the server without refreshing the page.

    So the simple answer to your question is that - no you don't need to reload the page to accomplish this.

    But, if you are ok (and more comfortable) with reloading the page, you can write JavaScript to fill a hidden field in a hidden form and use JavaScript to programmetically submit the form and handle everything in php on $_POST

    0 讨论(0)
  • 2021-01-28 19:36

    No you don't need to reload the page, especially since you are utilizing an asynchronous request (the A in AJAX) to the same URL.

    See this phpfiddle demonstrating your example (with a couple modifications). Click the Run - F9 button and then click the button labeled Board to run the JavaScript (with the AJAX request). If you open the browser console, you should see the requests in the Network tab. The main one should be a GET request to a page like code_41096139.php (the numbers will likely change). Then when the AJAX request is made, there should be a POST request to that same page. Expand that request and you should see the Form data.

    The only modifications made, besides adding the button and click handler, were to add the output element:

    <div id="output"></div>
    

    and then in the success callback of the AJAX request, set the text of that element to the response (in addition to the call to console.log()):

     success: function(response) {
          $('#output').text('response: '+response);
          console.log(response);
     }
    
    0 讨论(0)
  • 2021-01-28 19:39

    i think it will help you so send request and load data and if you want to reload page and if you want to search it also

       <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>PHP, jQuery search demo</title>
    <link rel="stylesheet" type="text/css" href="my.css">
    
     <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
    <script type="text/javascript">
    $(document).ready(function () {
        $("input").keyup(function () {
            $('#results').html('');
            var searchString = $("#search_box").val();
            var data = 'search_text=' + searchString;
            if (searchString) {
                $.ajax({
                    type: "POST",
                    url: 'search.php',
                    data: data,
                    dataType: 'text',
                    async: false,
                    cache: false,
                    success: function (result) {
                        $('#results').html(result);
                        //window.location.reload();
    
                    }
                });
            }
        });
    });
     </script>
    
    </head>
    <body>
    <div id="container">
    <div style="margin:20px auto; text-align: center;">
    <form method="post" action="do_search.php">
        <input type="text" name="search" id="search_box" class='search_box'/>
        <input type="submit" value="Search" class="search_button"/><br/>
    </form>
    </div>
    <div>
    
    <div id="searchresults">Search results :</div>
    <ul id="results" class="update">
    </ul>
    
    </div>
    </div>
    
    </body>
    </html>
    

    then create a php file

    <?php 
    
     $searchquery = trim($_POST['search_text']); 
    echo $searchquery;
    ?>
    

    you can add more code which you want like update database , insert search as you want

    0 讨论(0)
提交回复
热议问题