JQuery .post() return html into table

谁都会走 提交于 2020-01-06 13:56:37

问题


I have a form with two input boxes. Song and Artist. When the search button is pressed, it uses the JQuery function of .post() to post the data to a PHP page and return results back to the page.

Here is my JavaScript code:

<script>
    $(function() {

        $("#submitSearch").bind("click", function() {
            var songTitle = $("#song").val();
            var artistName = $("#artist").val();

            $.post("getSearchResults.php", {
                artist: artistName, 
                song: songTitle
            },
            function( data, status ) {
                $("#searchResults tbody").last().append( data );
            });
        });
    });
</script>

The goal is to put the results into the <tbody> of the "searchResults" table.

<table id="searchResults">
    <thead>
        <tr>
            <th>Title</th>
            <th>Artist</th>
            <th>Album</th>
            <th>Add To List</th>
        </tr>
    </thead>
    <tbody>
    </tbody>
</table>

However, it doesn't seem to be inserting the results into the table.

It's not until I put an alert() message in the Javascript Code that it shows it.

<script>
    $(function() {

        $("#submitSearch").bind("click", function() {
            var songTitle = $("#song").val();
            var artistName = $("#artist").val();

            $.post("getSearchResults.php", {
                artist: artistName, 
                song: songTitle
            },
            function( data, status ) {
                $("#searchResults tbody").last().append( data );
            });

            alert("test");

        });
    });
</script>

When I dismiss the "test" alert, it puts the results into the table and very quickly they disappear.

What am I missing here? Please help me! I am stumped. Thanks in advance.


回答1:


Try this...

<script>
    $(function() {

        $("#submitSearch").bind("click", function(e) {
            e.preventDefault();
            var songTitle = $("#song").val();
            var artistName = $("#artist").val();

            $.post("getSearchResults.php", {
                artist: artistName, 
                song: songTitle
            },
            function( data, status ) {
                $("#searchResults tbody").last().append( data );
            });
        });
    });
</script>

I added an event parameter to the click function, and e.preventDefault(). this stops the submit actually taking place, which is reloading your page. Also, depending on which version of jQuery you are using you may want to use on() instead of bind(). (It's exactly the same syntax as above.)



来源:https://stackoverflow.com/questions/19007165/jquery-post-return-html-into-table

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!