Muszę opublikować dane na stronie php, a następnie chciałbym uzyskać tekst pewnego elementu div, który jest w odpowiedzi, ale nie mogę ustawić wszystko poprawnie. Nie jestem zbyt dobra z jQuery, ale zazwyczaj mogę dość szybko zorientować się w problemach ... Byłem w tym przez chwilę i próbowałem wszystkiego, co znalazłem ... Myślę, że brakuje mi właściwej kombinacji rzeczy .Znajdowanie elementu za pomocą identyfikatora w odpowiedzi AJAX z jQuery
$.post("process.php", data , function (response) {
var w = window.open();
$(w.document.body).html(response);
console.log(typeof response); // yeilds string
//create jquery object from the response html
// var $data = $(response); // yeilds Uncaught Error: Syntax error, unrecognized expression: + whole html text
var success = $($.parseHTML(response)).find("#success");
console.log('success');
console.log(success); // see screenshot
console.log(success.text()); // yields nothing
console.log(success.val()); // yields undefined
// if (window.focus) {w.focus()};
},'html');
to wyjście console.log(success);
i czerwone pudełko jest to, co chcę z odpowiedzi ...
! [Ten obraz wydaje się naprawdę niewielka ... to nie było to, że kiedy zrobiłem mały to. Mam nadzieję, że nadal jest czytelny] [1]
i to robi, że:
var success = $(response).find("#success");
console.log('success');
console.log(success); // yeilds Uncaught Error: Syntax error, unrecognized expression: + whole html text in red
Response jest ...
<html><head>
<style>
div.totals {
font-family:calibri; font-size:.9em; display:inline-block;
border-width: 2px; border-style: solid; border-color: #FFD324;
background-color: #FAF5D7; color: #514721;
width: 500px;
}
div.error_invalid {
font-family:calibri; font-size:.9em; display:inline-block;
border-width: 2px; border-style: solid; border-color: #9999CC;
background-color: #EEEEFF; color: #7979B8;
}
</style>
</head>
<body>
<div class="totals">Total new rows added: 0 out of 0<br/></div>
<br/><br/>
<div class="totals">Total updated rows: 0 out of 0 <br/></div>
<div id="success">true</div>
</body></html>
i próbowałem usuwając część stylu i dodałem w znaczniki html, head i body w nadziei, że to pomogłoby ... znaczenie, mam te same problemy, jeśli odpowiedź składa się tylko z trzech div.
Może wyświetlać treść "respone" – pktangyue
tak. Nie byłem pewien, czy było to potrzebne, ponieważ to, co mi dało w zrzucie ekranu, wydawało się w tym momencie poprawnie interpretowane. –
Czy próbowałeś '$ (w.document.body) .find ('# success')'? – pktangyue