Jquery: мой класс не работает во время второго вызова - PullRequest
0 голосов
/ 15 декабря 2008

Я новичок в jQuery. Просто изучите и используйте его в течение 3 недель до сих пор. Я написал класс для организации вещей. Я вызываю мой метод с более чем 2 событиями, но событие не работает во время моего запуска второго события. нет ничего плохого в селекторе. Я думаю, что-то не хватает в моем классе. Я не знаю. пожалуйста помоги! вот фрагмент:

$("#btnPersonalNext, #btnDocListBack, #pDocList").livequery('click',function()
{
  var docListContent = 'loadDocumentList.php';
  $("#contentpaper").addContent(
  {
    _tag:'div',
    _id: 'contentDocList',
    _class: 'content',
    _content: docListContent,
    _heading: 'Document List'
  });
  //store personal info in session:
});

addContent() - это функция. когда я нажимаю #btnPersonalNext, это работает, но для #btnDocListBack, а не больше.

вот мой класс (jquery.content.js). он загружает html в определенный _tag с определенным _id.

(function($)
{
  $.fn.addContent = function(options)
  {
    var defaults = {
      _tag: 'div',
      _id: '',
      _class: '',
      _content: '',
      _heading: '',
      _clearExisting:'yes',
      _insertAfterID:'',
      _deleteBeforeInsert:'no'
    };
    var options = $.extend(defaults, options);

    return this.each(function()
    {
      obj = $(this);
      if(options._clearExisting=='yes'){
        obj.empty();
      }
      if(options._deleteBeforeInsert =='yes'){
        $('#'+options._id).remove();
      }

      var innerHtml = '<' + options._tag + ' id="' + options._id + '" class="' + options._class + '">';
      if(options._heading!=''){
        innerHtml += '<h2>' + options._heading + '</h2>';
      }

      if(/^[A-Za-z0-9]+\.php(\??([A-Za-z0-9]+=[A-Za-z0-9]+)(&[A-Za-z0-9]+=[A-Za-z0-9]+)*)?$/.test(options._content))
      {//if .php
        $.get(options._content,function(data)
        {
          //handle response from server here.
          innerHtml += data;
          innerHtml +='</' + options._tag + '>';
          if(options._insertAfterID !=''){
            $('#'+options._insertAfterID).after(innerHtml);
          }
          else{
            obj.html(innerHtml); 
          }
        });
      } // PHP rule 
      else
      {// .html
        innerHtml += options._content;
        innerHtml +='</' + options._tag + '>';
        if(options._insertAfterID !=''){
          $('#'+options._insertAfterID).after(innerHtml);
        }
        else{
          obj.html(innerHtml); 
        }
      } // HTML rule 
    }); // End of Returned Function
  };// End of addContent definition
})(jQuery);

надеясь на ответы, большое спасибо!

вот моя структура DOM:

<!-- JS  -->
<script type="text/javascript" src="jquery_plugins/jquery-1.2.6.js" ></script>
<script type="text/javascript" src="jquery_plugins/jquery.livequery.js" ></script>
<script type='text/javascript' src='jquery_plugins/jquery.simplemodal.js'></script>
<script type="text/javascript" src="jquery_plugins/jquery.session.js"></script>
<!--<script type="text/javascript" src="jquery_plugins/jquery-plugin-wrapinner.js"></script>-->
<script type="text/javascript" src="jquery_plugins/jquery.content.js"></script>
<script type="text/javascript" src="jquery_plugins/osra_main.js"></script>
</head>

<body>
<div id="wrapper">   
    <div id="header">
        <div id="headercontent">Please Enable JavaScript to Continue</div>
    </div>
    <div id="main">
        <div id="sidebarpaper" class="left">
            <!-- sidebar contents (class="sidebar")-->
        </div>
        <div id="contentpaper" class="right">
            <!-- main contents (class="content")-->
        </div>
        <div id="modals" class="clear">
            <!--modal pop-up window -->
        </div>
    </div>
    <div id="footer"><p></p></div>
</div>
</body>
</html>

Я загружаю содержимое динамически в div с идентификатором #contentpaper. Я не знаю, как перепривязать, кроме использования плагина livequery, с этим использованием: $("#btnID").livequery('click',function(){});

-bgreen1989

1 Ответ

2 голосов
/ 15 декабря 2008

Я быстро осмотрел его, и размер кода было немного сложно диагностировать, поэтому я немного пересмотрел его, надеясь сделать его более понятным для себя и других.

Я думаю, что это ЧАСТЬ проблемы, а BADTHING (TM) - это создание вами html путем склеивания строк. Это может нарушить привязку событий DOM и сделать действительно ужасный код.

Кроме того, видя, что вы полагаетесь на живой запрос, метод «склеить строки вместе» может не вызывать события dom, необходимые для выполнения трюка с живым запросом (не обязательно), и вы / можете / найдете использование методов DOM для генерации Элементы DOM должны решить эту проблему

(function($){
  $.fn.addContent = function(options)
  {
    var defaults = {
      _tag: 'div',
      _id: '',
      _class: '',
      _content: '',
      _heading: '',
      _clearExisting:'yes',
      _insertAfterID:'',
      _deleteBeforeInsert:'no'
    };
    var options = $.extend(defaults, options);
    var phpregex = /^[A-Za-z0-9]+\.php(\??([A-Za-z0-9]+=[A-Za-z0-9]+)(&[A-Za-z0-9]+=[A-Za-z0-9]+)*)?$/;

    var x_generateElement = function()
    {
      var container = document.createElement(options._tag); 
      $(container).attr("id", options._id); 
      $(container).addClass(options._class);
      if(options._heading!=''){
        var header = document.createElement("h2"); 
        $(header).text( options._heading ); 
        $(container).append(header);
      }
      return container;
    };

    var x_preClear   = function( obj )
    {
      if(options._clearExisting=='yes'){
        obj.empty();
      }
      if(options._deleteBeforeInsert =='yes'){
        $('#'+options._id).remove();
      }
      return obj
    };

    var x_addElement = function( e , obj )
    {      
      if(options._insertAfterID !=''){
            $('#'+options._insertAfterID).after(e);
      }
      else{
        obj.html(e); 
      }
      return obj;
    };

    return this.each(function()
    {
      var obj = x_preClear( $(this) );
      var container = x_generateElement(); 

      if( phpregex.test(options._content)){
        $.get(options._content,function(data){
          //handle response from server here.
          $(container).append(data);
          obj = x_addElement(container, obj);
        });
      } else {
        $(container).append(options._content);
        obj = x_addElement(container, obj);
      } 
    });
  };
})(jQuery);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...