HTML을 사용하여 테이블을 만들고 검색 상자를 통합하려고합니다. 어떻게해야합니까? 좋은 jQuery 플러그인을 권하거나 더 완벽한 튜토리얼을 추천 할 수 있습니까?HTML 테이블 검색
2
A
답변
1
테이블을 찾는 것은 간단 jQuery를 사용
$('#table1 tr td').each(function(){
if (this.innerHTML.indexOf(searchKeyword) > -1)
this.style.color = 'yellow' //found within this td so highlight it
});
3
빠르고 더러운 방법 : 이하의 (x)는 HTML을
$(document).ready(
function(){
$('#searchbox').keyup(
function(){
var searchText = $(this).val();
if (searchText.length > 0){
$('td:contains(' + searchText +')')
.css('background-color','#f00');
$('td:not(:contains('+searchText+'))')
.css('background-color','#fff');
}
});
});
:
<table>
<thead>
<tr>
<td colspan="2">
<label for="searchbox">Search:</label>
<input type="text" id="searchbox" />
</td>
</tr>
</thead>
<tbody>
<tr>
<td>Something</td>
<td>More text</td>
</tr>
<tr>
<td>Lorem ipsum</td>
<td>blah?</td>
</tr>
</tbody>
</table>
JS Fiddle demo. JQuery와 자체의 CSS를 설정하는 대신에 addClass()
/removeClass()
를 사용하는을 편집
:
$(document).ready(
function(){
$('#searchbox').keyup(
function(){
var searchText = $(this).val();
if (searchText.length > 0){
$('td:contains(' + searchText +')')
.addClass('searchResult');
$('td:not(:contains('+searchText+'))')
.removeClass('searchResult');
}
else if (searchText.length == 0) {
$('td.searchResult')
.removeClass('searchResult');
}
});
});
jQuery를 :
는 다음을 사용할 수있는 검색 결과를 포함하지 않는 테이블 셀을 페이드 아웃
$(document).ready(
function(){
$('#searchbox').keyup(
function(){
var searchText = $(this).val();
if (searchText.length > 0) {
$('tbody td:contains('+searchText+')')
.addClass('searchResult');
$('.searchResult')
.not(':contains('+searchText+')')
.removeClass('searchResult');
$('tbody td')
.not(':contains('+searchText+')')
.addClass('faded');
$('.faded:contains('+searchText+')')
.removeClass('faded');
}
else if (searchText.length == 0) {
$('.searchResult').removeClass('searchResult');
$('.faded').removeClass('faded');
}
});
});
CSS :
td.faded {
opacity: 0.2;
}
1
감사 데이빗 토마스
좋은 해결책. 다음은 완벽합니다.
$(document).ready(
function(){
$('#searchbox').keyup(
function(){
var searchText = $(this).val();
if (searchText.length > 0) {
$('tbody td:contains('+searchText+')')
.addClass('searchResult');
$('.searchResult')
.not(':contains('+searchText+')')
.removeClass('searchResult');
$('tbody td')
.not(':contains('+searchText+')')
.addClass('faded');
$('.faded:contains('+searchText+')')
.removeClass('faded');
$('.faded').hide();
$('.searchResult').show();
}
else if (searchText.length == 0) {
$('.searchResult').removeClass('searchResult');
$('.faded').removeClass('faded');
$('td').show();
}
});
});
2
은 큰 응답이 있습니다. 하지만 this 남자는 내가 정말로 원했던 것을했습니다. http://blogs.digitss.com/demo/jquery-table-search.html
출처 : 그것은 이전 답변
HTML
<label for="kwd_search">Search:</label> <input type="text" id="kwd_search" value=""/>
<table id="my-table" border="1" style="border-collapse:collapse">
<thead>
<tr>
<th>Name</th>
<th>Sports</th>
<th>Country</th>
</tr>
</thead>
<tbody>
<tr>
<td>Sachin Tendulkar</td>
<td>Cricket</td>
<td>India</td>
</tr>
<tr>
<td>Tiger Woods</td>
<td>Golf</td>
<td>USA</td>
</tr>
<tr>
<td>Maria Sharapova</td>
<td>Tennis</td>
<td>Russia</td>
</tr>
</tbody>
</table>
자바 스크립트 (jQuery를)
// When document is ready: this gets fired before body onload <img src='http://blogs.digitss.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' />
$(document).ready(function(){
// Write on keyup event of keyword input element
$("#kwd_search").keyup(function(){
// When value of the input is not blank
if($(this).val() != "")
{
// Show only matching TR, hide rest of them
$("#my-table tbody>tr").hide();
$("#my-table td:contains-ci('" + $(this).val() + "')").parent("tr").show();
}
else
{
// When there is no input or clean again, show everything back
$("#my-table tbody>tr").show();
}
});
});
// jQuery expression for case-insensitive filter
$.extend($.expr[":"],
{
"contains-ci": function(elem, i, match, array)
{
return (elem.textContent || elem.innerText || $(elem).text() || "").toLowerCase().indexOf((match[3] || "").toLowerCase()) >= 0;
}
});
라이브 데모에서가 두드러 다르다 http://blogs.digitss.com/javascript/jquery-javascript/implementing-quick-table-search-using-jquery-filter/
관련 문제
- 1. JQuery로 HTML 테이블 검색
- 2. C++의 검색 테이블
- 3. 여러 데이터베이스에서 테이블 검색
- 4. 테이블 검색 (COBOL)
- 5. 쿼리에서 여러 테이블 검색
- 6. mysql, 검색 테이블 기능
- 7. findbysql 2 테이블 검색
- 8. 두 테이블 사이에서 검색
- 9. SQL 테이블 검색
- 10. 있는 jqGrid 테이블 검색
- 11. ASP.NET에서 html 테이블 나누기
- 12. 고정 헤더가있는 HTML 테이블
- 13. PHP HTML 테이블 출력
- 14. BeautifulSoup로 HTML 테이블 분석
- 15. HTML 테이블 아래쪽으로 스크롤
- 16. 테이블 테두리 html
- 17. 엑셀로 HTML 테이블 내보내기
- 18. 격자가있는 HTML/CSS 테이블
- 19. HTML 중첩 테이블 스크롤
- 20. 여러 HTML 테이블 렌더링
- 21. 데이터베이스에서 html 테이블 채우기
- 22. Excel의 html 테이블 복사
- 23. HTML 테이블 td 맞춤
- 24. HTML 테이블 도움말
- 25. HTML 테이블 형식 질문
- 26. html 테이블 행 재정렬
- 27. 이중 테두리가있는 HTML 테이블?
- 28. HTML 테이블 세포가 제대로
- 29. HTML 테이블 질문
- 30. 젠드 테이블 html 도우미
great..thnks 헤이 .. 강조 표시 대신 원하는 검색 만 표시하는 방법 그것? – craig