Skip to main content

How to change url or submit form into url without refresh page by jQuery?

Change url or submit form into url without refresh page by jQuery?
 

<html>

    <head>

    <script src="https://code.jquery.com/jquery-3.6.3.min.js" integrity="sha256-pvPw+upLPUjgMXY0G+8O0xUf+/Im1MZjXxxgOcBQBXU=" crossorigin="anonymous"></script>

    </head>

    <body>

        <Form action="" method="get" id="search_form">

            <input type="text" name="first_name" value="demo">

            <input type="text" name="last_name" value="tester">

            <input type="text" name="city" value="sangrur">

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

        </Form>

    </body>

    <Script>

        jQuery("document").ready(function($){

            $('#search_form').submit(function(e){

                e.preventDefault();

                var search_form = $(this).serialize();

                var refresh = window.location.protocol + "//" + window.location.host + window.location.pathname + '?arg=1&' + search_form;    

                window.history.pushState({ path: refresh }, '', refresh);


                var current_url = window.location.href;

                var url_data = parseURLParams(current_url);

                console.log(url_data);

                console.log(url_data['first_name']);

                

            })

            function parseURLParams(url) {

                var queryStart = url.indexOf("?") + 1,

                    queryEnd   = url.indexOf("#") + 1 || url.length + 1,

                    query = url.slice(queryStart, queryEnd - 1),

                    pairs = query.replace(/\+/g, " ").split("&"),

                    parms = {}, i, n, v, nv;


                if (query === url || query === "") return;


                for (i = 0; i < pairs.length; i++) {

                    nv = pairs[i].split("=", 2);

                    n = decodeURIComponent(nv[0]);

                    v = decodeURIComponent(nv[1]);


                    if (!parms.hasOwnProperty(n)) parms[n] = [];

                    parms[n].push(nv.length === 2 ? v : null);

                }

                return parms;

            }

        });

    </Script>

</html>

Comments

Popular posts from this blog

How to use inner html value or data in php from javascript(innerHTML)?

 use inner html value or data in php from javascript(innerHTML)? <html> <body> <p id="demo">use inner html value in php(innerhtml)</p> <script>   var jassi = document.getElementById("demo").innerHTML;   //document.write(jassi); </script> <?php $jassi = '<script>document.write(jassi);</script>'; echo $jassi; ?> </body> </html>

How to get store data from WCFM(Best Multi Vendor Marketplace) Plugin?

 Get store data from WCFM(Best Multi Vendor Marketplace) Plugin. global $WCFM, $WCFMmp, $wp, $WCFM_Query, $post; $store_id = ''; if ( isset( $attr['id'] ) && !empty( $attr['id'] ) ) { $store_id = absint($attr['id']); } if (  wcfm_is_store_page() ) { $wcfm_store_url = get_option( 'wcfm_store_url', 'store' ); $store_name = apply_filters( 'wcfmmp_store_query_var', get_query_var( $wcfm_store_url ) ); $store_id  = 0; if ( !empty( $store_name ) ) { $store_user = get_user_by( 'slug', $store_name ); } $store_id    = $store_user->ID; } $user_id = $store_id;  $vendor_data = get_user_meta( $user_id, 'wcfmmp_profile_settings', true ); $street_1 = $vendor_data['address']['street_1']; $street_2 = $vendor_data['address']['street_2']; $city     = $vendor_data['address']['city']; $zip      = $vendor_data['address']['zip&#

How to create login with phone number in woocommerce wordpress?

Create login with phone number in woocommerce wordpress. function wooc_extra_register_fields() {?>        <p class="form-row form-row-wide">        <label for="reg_billing_phone"><?php _e( 'Phone', 'woocommerce' ); ?><span class="required">*</span></label>        <input type="text" class="input-text" name="billing_phone" id="reg_billing_phone" value="<?php esc_attr_e( $_POST['billing_phone'] ); ?>" />        </p>            <?php  }  add_action( 'woocommerce_register_form_start', 'wooc_extra_register_fields' );  function wooc_validate_extra_register_fields( $username, $email, $validation_errors ) { if ( isset( $_POST['billing_phone'] ) ) {    $hasPhoneNumber= get_users('meta_value='.$_POST['billing_phone']);    if ( !empty($hasPhoneNumber)) {      $validation_er