Имам връзка, която извиква ajax за зареждане на съдържание и след като съдържанието се зареди, функцията ми jquery вече не работи
Ето го моят HTML
<a href="/bg#" onclick="javascript:makeRequest('content.html','');">Load Content</a>
<span id="result">
<table id="myTable" valign="top" class="tablesorter">
<thead>
<tr>
<th>Title 1</th>
<th>Level 1</th>
<th>Topics</th>
<th>Resources</th>
</tr>
</thead>
<tbody>
<tr>
<td>Example title 1</td>
<td>Example level 1</td>
</tr>
<tr>
<td>Example title 2</td>
<td>Example level 2</td>
</tr>
</tbody>
</table>
</span>
Таблицата е сортирана с помощта на плъгина за сортиране на таблици jquery от http://tablesorter.com/docs/ След ajax съдържанието е заредено, ще се покаже друг набор от таблици с различни данни. Сортирането обаче вече не работи.
Ето моят ajax скрипт, който се използва за зареждане на съдържанието:
var http_request = false;
function makeRequest(url, parameters) {
http_request = false;
if (window.XMLHttpRequest) { // Mozilla, Safari,...
http_request = new XMLHttpRequest();
if (http_request.overrideMimeType) {
// set type accordingly to anticipated content type
//http_request.overrideMimeType('text/xml');
http_request.overrideMimeType('text/html');
}
} else if (window.ActiveXObject) { // IE
try {
http_request = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
http_request = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {}
}
}
if (!http_request) {
alert('Cannot create XMLHTTP instance');
return false;
}
http_request.onreadystatechange = alertContents;
http_request.open('GET', url + parameters, true);
http_request.send(null);
}
function alertContents() {
if (http_request.readyState == 4) {
// alert(http_request.status);
if (http_request.status == 200) {
//alert(http_request.responseText);
result = http_request.responseText;
document.getElementById('result').innerHTML = result;
} else {
alert('There was a problem with the request.');
}
}
}
Някаква идея как мога да накарам добавките jquery да работят, след като съдържанието е заредено? Търсих и промених функцията за щракване jquery.tablesorter.js в live() като тази $headers.live("click",function(e)
, но тя също не работи.
Как мога да накарам функциите на jquery да работят, след като съдържанието е заредено? Благодаря ти
Актуализирайте скрипта за тестване:
<a href="/bg#" id="test" onClick="contentDisp()">Load Content</a>
<div id="result"></div>
<script type="text/javascript">
function contentDisp()
{
$.ajax({
url : "test.html",
success : function (data) {
$("#result").html(data);
$("#myTable").tablesorter();
$("#myTable").trigger("update");
}
});
}
</script>
Това е моят test.html. Сортирането на таблицата работи, ако не го поставя в заредено съдържание. След като се зареди в div, сортирането вече не работи.
<table id="myTable" valign="top" class="tablesorter">
<thead>
<tr>
<th class="header">Title 1</th>
<th class="header">Level 1</th>
</tr>
</thead>
<tbody>
<tr>
<td>Example title 1</td>
<td>Example level 1</td>
</tr>
<tr>
<td>Example title 2</td>
<td>Example level 2</td>
</tr>
</tbody>
</table>
$("#result")
. Ако сте използвали jQuery, можете да получите достъп до div в контекста на върнатите данни. Това би било полезно за вашия случай, чувствам. - person sirhc   schedule 20.05.2010