Jquery ... Как проверить переключатель при нажатии строки, сгенерированной CodeIgniter Ajax / JSON - PullRequest
0 голосов
/ 05 октября 2011

Я хотел, чтобы радио-кнопка проверяла, когда щелкают по ее конкретной строке, но она не работает. Я подозреваю, что проблема селектора jquery с таблицей, сгенерированной ajax / json. Это мой список кодов. Я новичок в Stackoverflow.

            <html>
            <head>
            <script type="text/javascript" src="<?php echo base_url();?>js/jquery-1.6.1.min.js"></script>
            <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
            <title>Untitled Document</title>
            <style type="text/css">
            <!--

            .selected td { background-color: #FF0000; }

            -->
            </style>
            </head>
            <body>
            <div id="search_form">
              <form id="form1" name="form1" method="post" action="">
                  <table width="80%" border="1" align="center" cellspacing="0">
                    <tr>
                      <td><label>
                        <div align="center">
                          <p>
                            <input name="search_input" type="text" id="search_input" value="ASET" size="50" />
                          </p>
                        </div>
                      </label></td>
                      <td width="10%" rowspan="2"><div align="center" id="btn_search">Search</div></td>
                    </tr>
                    <tr>
                      <td><label>
                        <div align="center">
                        <input name="rb_searchType" type="radio" id="cb_searchType" value="fileno" checked="checked" />
                      File No
                       <input type="radio" name="rb_searchType" id="cb_searchType2" value="filetitle" />
                      Title</div>
                      </label></td>
                    </tr>
                  </table>
                  <div align="center"></div>
                  <div align="center"></div>
              </form>
            </div>

            <div id="status_submit">
            </div>
            <div id="search_result1">
            </div>
            </body>
            <script type="text/javascript">
            $(document).ready(function() {

                $('#btn_search').click(function() {
                    $('#form1').submit();
                });

                $("form").submit(function() {

                  var fSearchInputValue = $('#search_input').attr('value');
                  var fSearchType = $("input[@name='rb_searchType']:checked").val();

                 $('#status_submit').html("please wait......");
                  $.ajax({
                        type: "POST",
                        url: "<?php echo site_url('files/search_list_file_json/'); ?>"+"/",
                        data: "SearchInputValue="+ fSearchInputValue +"& SearchType="+ fSearchType,
                        dataType: "json",
                        success: function(data) {
                        var contentHtml = '<table width="100%" border="1" cellpadding="2" cellspacing="0" bordercolor="#000000" id="Table"><tr><td width="5%">&nbsp;</td><td width="15%">FILE NO&nbsp;</td><td>SUBJECT&nbsp;</td></tr>';

                            $(data).each(function(index, item) {
                                contentHtml += '<tr><td><input type="radio" name="rb_fileno" id="rb_fileno" value="';
                                contentHtml += item.FileNo;
                                contentHtml += '" />&nbsp;</td>';               
                                contentHtml += '<td>';
                                contentHtml += item.FileTitle;
                                contentHtml += '&nbsp;</td></tr>';  
                            });

                        contentHtml += "</table>";
                          $('#search_result1').html(contentHtml);
                          $('#status_submit').fadeIn(function(){$('#status_submit').html('');});

                        },
                        error: function(){
                            var contentHtml='No result';
                            $('#status_submit').fadeIn(function(){$('#status_submit').html(contentHtml);});         
                        }
                    });

            return false;
                }); //end ajax json

                //check radio button when row is clicked
                 $('#search_result1s tr').click(function(event) {
                    // $(data).filter('div.search_result1 tr').click(function(event) {

                    $(this).find('td input:radio').prop('checked', true);
                    $(this).addClass("selected").siblings().removeClass("selected");
                 });

            }); // end document.ready

            </script>
            </html>

Спасибо

Ответы [ 2 ]

1 голос
/ 06 октября 2011

Попробуйте это

$('#search_result1s tr').live('click',function(event) {
    $(this).find('td :input[type=radio]').attr({'checked':'checked'});
     ...
});

в основном метод .live () работает аналогично .click (), разница только в том, что когда вы динамически добавляете html-элемент в тело, значит, после загрузки страницы .live () завершается успешно, а метод .click () завершается неудачей.

0 голосов
/ 05 октября 2011

выглядит как опечатка для меня.не должен

$('#search_result1s tr').click(function(event)

быть

$('#search_result1 tr').click(function(event)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...