.find()不适用于某些ID

时间:2016-09-29 10:30:56

标签: php jquery html get find

在我的网站中,客户可以更新他们的个人数据。在数据库上完成更新后,我希望页面自动更新并显示当时的数据。为此,我对外部php文件进行ajax调用以更新mysql数据库。之后,我获取客户端数据页面(location.href)并更新一些div信息以显示新数据。

这是来自我的JS文件的AJAX调用:

$.ajax({
    type: "POST",
    url: "factupdate.php",
    data: {
        datos: stringDatos, 
        token: $("#token").val(), 
        isAjax: 1
    },
    success: function (codi) {
        $.get(location.href, function (datos) {
            ($(datos)).find("#eltoken").html());
            var eltoken = $(datos).find("#eltoken");
            var result = $(datos).find("#cuenta_menu_fac");
            console.log($(eltoken).html());
            console.log($(result).html());
            $(result).find(".facturacion").hide();
            $(result).find("#fac_" + num).show();
            $(result).find(".afac").removeClass("aliselected");
            $(result).find("#menu_fac_" + num).addClass("aliselected");
            $(result).find("#acc_fac").append('<span class="goodvalid">Datos de facturación actualizados</span>');
            $("#cuenta_menu_fac").html($(result).html());
            $("#eltoken").html($(datos).find("#eltoken").html());
            $("#cargandoacc").hide();
        });
    },
    error: function (e) {
        $("#cargandoacc").hide();
        alert('Ha habido un error: ' + e);
    }
});

问题是我可以看到结果数据而不是eltoken,控制台打印未定义。

此外,当我尝试console.log($(datos).html());时,它也显示为未定义。另一方面,如果我做console.log($(datos).text());,它确实会返回网站的正确数据。

这是一些数据信息:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" lang="es" xml:lang="es">
<head>
...
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
...
</head>
<body>
<!-- Some layout divs -->



<div id="cuenta_menu_fac" class="c-menu-content">
<div class="content" id="acc_fac">

<!-- Some label and input for updating data divs -->

</div>
</div>




<!-- /Some layout divs -->
<div id="eltoken">
<input type="hidden" id="token" value="2d5951d1e3b31dfb7fd2dcc172df17fd">
</div>
</body></html>

我不明白我的代码有什么问题。任何可能的解决方案?

1 个答案:

答案 0 :(得分:1)

Datos不是eltoken的父级。只需添加例如。一个共同的div

$.get(location.href, function (datos) {
    datos = $('<div></div>').append(datos);
    ($(datos)).find("#eltoken").html());
    ...

参见我的类似例子 https://jsfiddle.net/011g253w/1/

<强>更新

您的代码在正文的一个级别上有2个div。并且get作为选择器$(*, 'body') = 2个div的数组的结果返回它。

我为你的案子找到了更好的方法。

var eltoken = $(datos).filter("#eltoken");
var result = $(datos).filter("#cuenta_menu_fac");

https://jsfiddle.net/011g253w/2/