javascript - Ajax - 在搜索字段清空后重新加载 div 中的先前数据

标签 javascript php jquery html ajax

我有一个小的 ajax 脚本,我可以使用它来搜索和加载结果,而无需重新加载或重定向页面:

$(document).ready(function(){

$('#db-search').keyup(function(){

    var txt = $(this).val();

    if(txt != ''){
        $('#db-search-results').html('');
        $.ajax({
            url: 'search.php',
            method: 'post',
            data:{search:txt},
            dataType: 'text',
            success:function(data){
                $('#db-search-results').html(data);
            }
        });
    } else{
        //reload previus data
    }

});

});

它可以工作,但有一个问题。在 #db-search 字段中输入任何内容之前,我已经在 #db-search-results 中显示数据库中的所有结果。现在,当我搜索某些内容时,所有以前的数据都会被这些新结果替换,但是如果我清除搜索字段,我的结果就会消失(这没关系),但我以前的数据不会回来。

有没有办法在清除搜索字段后保留以前的数据?

P.S:目前我只是执行 SELECT * 查询,然后使用 $('#db-search-results').html('search. php'); 但这是一个额外的查询,我宁愿寻找另一种方法来做到这一点:D

最佳答案

页面加载后,您可以将其存储在变量中,并在需要时显示它:

$(document).ready(function(){
    var default_data = $('#db-search-results').html();

    $('#db-search').keyup(function(){
        var txt = $(this).val();

        if(txt != ''){
            $('#db-search-results').html('');
            $.ajax({
                url: 'search.php',
                method: 'post',
                data:{search:txt},
                dataType: 'text',
                success:function(data){
                    $('#db-search-results').html(data);
                }
            });
        } else{
            $('#db-search-results').html(default_data);
        }
    });
});

关于javascript - Ajax - 在搜索字段清空后重新加载 div 中的先前数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51862978/

相关文章:

javascript - 使用 JavaScript 建模 3D 多面体

javascript - javascript 和 java 操作文件中的字符串列表值不同

jquery - jQuery mmenu 插件完成激活后是否有回调或任何其他方式执行函数?

javascript - 如何打开特定的 Accordion div?

javascript - 当固定 DIV 滚动到另一个 HTML 元素时动态添加 CSS 类

Javascript - I.E.、Chrome、Firefox - 如何包含外部 .js 文件?

javascript - 无法在 Firefox OS 上的 Facebook 和 Twitter native 应用程序上访问 'share' URL

php - “未知表”,尽管它确实存在

java - 事件与引用共享

javascript - 如何在数据chart.js中插入php