Ajax зареди съдържание, jquery добавките не работят

Имам връзка, която извиква 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>      

person Sylph    schedule 20.05.2010    source източник
comment
Защо ще си създавате всички проблеми с http_request, когато jQuery има вградена функция за зареждане, която го прави много по-лесно? api.jquery.com/load   -  person jbnunn    schedule 20.05.2010
comment
Връзките ми са динамични, имам проблем с присвояването на различния div id, затова използвам другия ajax метод   -  person Sylph    schedule 20.05.2010
comment
Можете да получите достъп до идентификатори на div като $("#result"). Ако сте използвали jQuery, можете да получите достъп до div в контекста на върнатите данни. Това би било полезно за вашия случай, чувствам.   -  person sirhc    schedule 20.05.2010
comment
Благодаря, редактирах скрипта си. Разбрах, че това не се случва само при сортирането на таблици, но и при всеки друг jquery плъгин. След като съдържанието се зареди, всички jquery добавки не работят в новото заредено съдържание.   -  person Sylph    schedule 21.05.2010


Отговори (1)


Трябва да извикате $("#myTable").trigger("update");, след като данните от таблицата бъдат вмъкнати.

Моля, разгледайте този пример на уебсайта на tablesorter, може да ви помогне да почистите кода си и за зареждането на съдържанието.

Ако имате нужда от повече помощ/код, просто публикувайте коментар. (Мисля, че ще е по-добре за вас да го разберете, вместо да се храните с лъжица, затова не го включвам тук.)

person sirhc    schedule 20.05.2010
comment
Здравейте, благодаря много за отговора. :) Добавянето на таблица работи, но нямам намерение да добавям таблицата. Проблемът е, че изглежда, че всички други функции на jquery не работят добре, след като съдържанието се зареди с помощта на ajax. :( - person Sylph; 21.05.2010
comment
Имам отговора. Благодаря ви много за началото! Използвам това, за да извикам отново функцията, след като съдържанието е заредено и да върна успех :) $(.tablesorter).tablesorter(); - person Sylph; 21.05.2010