云自無心水自閑

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

          prototype版的table filter

          Posted on 2010-07-28 11:02 云自無心水自閑 閱讀(1980) 評論(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
          大家一起互相學習是最有效的方法
          主站蜘蛛池模板: 蚌埠市| 金湖县| 财经| 道孚县| 临沧市| 大安市| 海盐县| 荔波县| 鄱阳县| 高台县| 苏尼特右旗| 将乐县| 沈丘县| 县级市| 伊宁市| 上栗县| 湖北省| 闵行区| 禹城市| 五常市| 大名县| 天柱县| 清远市| 泗阳县| 黎平县| 渑池县| 莱州市| 巴林左旗| 昌平区| 大同市| 临夏县| 上犹县| 横山县| 阳高县| 上蔡县| 兴义市| 霍城县| 杭锦旗| 福建省| 临邑县| 临澧县|