Javascript поиск подстроки - PullRequest
0 голосов
/ 28 апреля 2011

Я пытаюсь написать функцию javascript, которая будет искать все указанные элементы div на html-странице для подстроки, содержащейся в моей панели поиска.Как я могу сделать это просто?

Вот мой код, у меня он работает так, что метод showMe будет отображать только выбранные элементы div, мне просто нужен код подстроки для работы сейчас.Может ли кто-нибудь помочь, пожалуйста?

   <html>

<head>
<script type="text/javascript"> 
<!-- 
function dynamicSearch() {
    var val = document.getElementById('search').value;
    if (val == '')
      val = '-1';
    var srch = new RegExp(val, "gi");
    var els = document.getElementsByClassName('row');
    for (var idx in els) {
      if (idx != parseInt(idx))
        continue;
      var el = els[idx];
      if (typeof(el.innerHTML) !== 'undefined') {
        console.log(el.innerHTML);
        if (srch.test(el.innerHTML)) {
          el.style.display = 'block';
        } else {
          el.style.display = 'none';
        }
      }
    }
  }

function showMe (it, box) { 
var vis = (box.checked) ? "block" : "none"; 
document.getElementById(it).style.display = vis;
} 
//--> 
</script>
</head>

<body>

<form>
<label for="search">Search:</label>
            <input type="text" name="search" id="search" onkeyup="dynamicSearch()"/>

<input type="checkbox" name="modtype" value="value1" onclick="showMe('div1', this)" />value1

<input type="checkbox" name="modtype" value="value2" onclick="showMe('div2', this)" />value2

<input type="checkbox" name="modtype" value="value3" onclick="showMe('div3', this)" />value3

<input type="checkbox" name="modtype" value="value4" onclick="showMe('div4', this)" />value4

<input type="checkbox" name="modtype" value="value5" onclick="showMe('div5', this)" />value5

<div class="row" id="div1" style="display:none">Show Div 1</div>
<div class="row" id="div2" style="display:none">Show Div 2</div>
<div class="row" id="div3" style="display:none">Show Div 3</div>
<div class="row" id="div4" style="display:none">Show Div 4</div>
<div class="row" id="div5" style="display:none">Show Div 5</div>
</form>

</body>

</html>

1 Ответ

1 голос
/ 28 апреля 2011

С jQuery это лот проще.

Например, ваша функция dynamicSearch может быть заменена на:

function dynamicSearch() {
    var val = $('#search').val();
    if (val == '') val = '-1';
    var srch = new RegExp(val, "gi");

    $('.row').each(function(i, el) {
        if ($(this).text().match(srch)) {
            $(this).show();
        } else {
            $(this).hide();
        }
    });
}

иВы также можете получить анимационные эффекты бесплатно, чего вы не можете легко сделать, просто установив свойство CSS display.

Я поставил рабочую скрипку на http://jsfiddle.net/alnitak/nLxc4/, которую я думаю делает то, что вы просите.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...