DEV Community

Falah Al Fitri
Falah Al Fitri

Posted on • Edited on

1 1

PHP Javascript form formData 50: input text textarea checkbox using ajax (XMLHttpRequest)


Happy Coding

index.php

    <form method="post" action="process.php" >

        Firstname: <input type="text" name="firstname" />
        <br />

        Lastname: <input type="text" name="lastname" />
        <br />

        Description: <textarea name="description" rows="10" cols="50" ></textarea>
        <br />

        Hobby (single): <input type="checkbox" name="hobby" value="studying" /> Studying
        <br />

        <hr />

        <input type="submit" value="Submit" />

    </form>

    <hr />
Enter fullscreen mode Exit fullscreen mode

display result form server

    <div id="output"></div>
Enter fullscreen mode Exit fullscreen mode

get formHTML element and add onsubmit event, and create formData, then call ajax function with arguments formHTML, formData and output display ("#output")

    <script>

        /* submit form */
        document.querySelector( "form" ).addEventListener( "submit", function (event) {

            event.preventDefault(); // return false


            var formHTML = event.target; // this

            console.log( formHTML ); // formHTML element


            // https://developer.mozilla.org/en-US/docs/Web/API/FormData/Using_FormData_Objects
            var formData = new FormData( formHTML );

            console.log( formData );


            // https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest
            // https://www.w3schools.com/xml/xml_http.asp
            // https://www.w3schools.com/js/js_ajax_http.asp

            /* AJAX request */
            ajax( formHTML, formData, "#output" ); // ajax( form, data destination )

        });

    </script>
Enter fullscreen mode Exit fullscreen mode

ajax function

    <script>

        function ajax( form, data, destination )
        {

            if (window.XMLHttpRequest)
            {
                var xhr = new XMLHttpRequest(); /* code for modern browsers */
            }
            else
            {
                var xhr = new ActiveXObject("Microsoft.XMLHTTP"); /* code for old IE browsers */
            }

            xhr.open( form.method, form.action, true ); // ( "post", "process.php", true )
            xhr.send( data );

            xhr.onreadystatechange = function () {
                if ( this.readyState == 4 && this.status == 200 )
                {
                    document.querySelector( destination ).innerHTML = this.responseText;
                }
            };

        }

    </script>
Enter fullscreen mode Exit fullscreen mode

process.php

echo "<pre>";

var_dump($_POST);

echo "</pre>";
Enter fullscreen mode Exit fullscreen mode

Demo repl.it


Thank for reading :)

Sentry blog image

How I fixed 20 seconds of lag for every user in just 20 minutes.

Our AI agent was running 10-20 seconds slower than it should, impacting both our own developers and our early adopters. See how I used Sentry Profiling to fix it in record time.

Read more

Top comments (0)

nextjs tutorial video

Youtube Tutorial Series 📺

So you built a Next.js app, but you need a clear view of the entire operation flow to be able to identify performance bottlenecks before you launch. But how do you get started? Get the essentials on tracing for Next.js from @nikolovlazar in this video series 👀

Watch the Youtube series

👋 Kindness is contagious

Please leave a ❤️ or a friendly comment on this post if you found it helpful!

Okay