云自無心水自閑

          天平山上白云泉,云自無心水自閑。何必奔沖山下去,更添波浪向人間!
          posts - 288, comments - 524, trackbacks - 0, articles - 6
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          prototype版的table filter

          Posted on 2010-07-28 11:02 云自無心水自閑 閱讀(1989) 評論(1)  編輯  收藏 所屬分類: 心得體會JQueryTapestry

          jquery有一個很方便的插件UI Table Filter可以根據輸入的內容隱藏顯示表格中相應的數據行。
          因為目前使用的tapestry捆綁的是prototype,所以就自己寫了一個類似的插件。

          <html>
          <head>
          <script src="prototype-1.6.0.2.js" type="text/javascript"></script>
          <script language="javaScript">
           Event.observe(window, 'load', function() {
            Event.observe('filter', 'keyup', filterTable);
           });
           function filterTable() {
            var filterCaseElement = document.getElementById('filterCase');
            var caseSensitive = filterCaseElement.checked;
            
            $$('tr').each(function(trElement, ind) {
             var val = $('filter').value;
             
             if ( ! caseSensitive ) {
              val = val.toLowerCase();
             }
                 
             trElement.childElements().each(function(tdElememt) {
               var tdText = tdElement.innerText;
              if ( ! caseSensitive ) {
               tdText = tdText.toLowerCase();
              }
              if (tdText.include(val)) {
               trElement.show();
              } else if ( ind > 0 ) {
               trElement.hide();
              }
             });
            });
           }
          </script>

          </head>

           <body>
            filter: <input type="text" id="filter" name="filter"/> <input type="checkbox" id="filterCase" onchange="javaScript:filterTable();"/> Case-Sensitive
            <table border="1">
             <thead>
              <tr>
               <th>name</th>
               <th>column1</th>
               <th>column2</th>
               <th>column3</th>
               <th>column4</th>
               <th>column5</th>
               <th>column6</th>
              </tr>
             </thead>
             <tr>
              <td>TEST</td>
              <td>00150002331</td>
              <td>238156</td>
              <td>075</td>
              <td>001</td>
              <td>172.16.14.20</td>
              <td>1-1-05</td>
             </tr>
             <tr>
              <td>TEST-2</td>
              <td>00150002332</td>
              <td>238157</td>
              <td>075</td>
              <td>002</td>
              <td>172.16.14.21</td>
              <td>1-1-05</td>
             </tr>
             <tr>
              <td>TEST</td>
              <td>00150002333</td>
              <td>238158</td>
              <td>075</td>
              <td>003</td>
              <td>172.16.14.23</td>
              <td>1-1-05</td>
             </tr>
             <tr>
              <td>TEST</td>
              <td>00150002341</td>
              <td>238159</td>
              <td>075</td>
              <td>004</td>
              <td>172.16.14.24</td>
              <td>1-1-05</td>
             </tr>
             <tr>
              <td>TEST</td>
              <td>00150002339</td>
              <td>238186</td>
              <td>075</td>
              <td>006</td>
              <td>172.16.14.26</td>
              <td>1-1-06</td>
             </tr>
            </table>
           </body>
            </html>

          如果頁面中多個表格,而只需要對其中的一個表格的數據進行過濾的話,簡單地把其中:$$('tr').each(function(ele, index) 改成 $$('#tableId, tr').each(function(ele, index) 就行了,其中的tableId就是表格的id


          評論

          # re: prototype版的table filter  回復  更多評論   

          2010-07-28 12:05 by usherlight
          大家一起互相學習是最有效的方法
          主站蜘蛛池模板: 安龙县| 威海市| 绥江县| 青阳县| 大埔县| 淮安市| 交口县| 都匀市| 孟州市| 沾益县| 福安市| 唐海县| 临洮县| 白山市| 凤山市| 金湖县| 祁东县| 崇文区| 漠河县| 洮南市| 观塘区| 新营市| 四会市| 奉节县| 小金县| 三亚市| 长兴县| 青阳县| 富蕴县| 凉城县| 柏乡县| 兴仁县| 长治县| 涞水县| 平阴县| 樟树市| 汉川市| 金乡县| 桐城市| 黎平县| 卢龙县|