簡體   English   中英

使用JavaScript標記列表中的單詞

[英]Use JavaScript to Flag a Word From a List

我正在嘗試使用javascript從集合列表中標記單詞,但是它似乎無法正常工作。 基本上,我希望用戶能夠輸入一個單詞,如果它與右側列表中的任何單詞匹配,則將其標記為紅色。

有什么想法我做錯了嗎?

http://jsfiddle.net/Copernicus76/rpuXW/embedded/result/

// Load the banned plates json data

  var platesJson = (function () {
      platesJson = null;
      $.ajax({
          'async': false,
              'global': false,
              'url': "bannedplates.json",
              'dataType': "json",
              'success': function (bannedplates) {
              platesJson = bannedplates;
          }
      });
      return platesJson;
  })();


  $(document).ready(function () {

      // Draw the list //

      $.each(platesJson, function (i) {
          $('#plate-list').append('<div class="row-' + i + '">' + platesJson[i].plate + '</div>');
      });


      // Search the banned plates //

      $('#plate-text').keyup(function () {

          var result = '';
          var plateRow = '';
          var scrollPosition;
          var searchText = $('#plate-text').val().toUpperCase();

          $.each(platesJson, function (i) {
              if (searchText == platesJson[i].plate) {
                  result = 'banned';
                  plateRow = i;
                  scrollPosition = i * 19;
              }

          });

          if (/\S/.test(searchText)) {

              if (result == 'banned') {
                  $('#plate-intro,#plate-ok').hide();
                  $('#plate-banned').show().fadeOut(1500);
                  $('#plate-text').addClass('banned');
                  $('#plate-list').animate({
                      scrollTop: scrollPosition
                  }, 1000);
                  $('#plate-list div.row-' + plateRow + '').addClass('banned');
              } else {
                  $('#plate-intro,#plate-banned').hide();
                  $('#plate-ok').show().fadeOut(1500);
                  $('#plate-text').removeClass('banned');
              }

          } else {
              $('#plate-text').val('');
              $('#plate-ok,#plate-banned').hide();
              $('#plate-intro').show();
          }

      });

  }); // end document ready
  var platesJson = (function () {
      platesJson = null;
      $.ajax({
          'async': false,
          'global': false,
          'url': "bannedplates.json",
          'dataType': "json",
          'success': function (bannedplates) {
              platesJson = bannedplates;
          }
      });
      return platesJson;
  })();

那不是ajax的工作方式。 a表示asynchronous ,因此成功函數將在響應返回時運行。 這不會立即發生,可能要花幾分鍾,甚至可能完全失敗。 success方法是回調 那是您想要做魔術的地方。

  $.ajax({
      'async': false,
      'global': false,
      'url': "bannedplates.json",
      'dataType': "json",
      'success': function (bannedplates) {
          $.each(bannedplates, function (i) {
              $('#plate-list').append('<div class="row-' + i + '">' + bannedplates[i].plate + '</div>');
          });
          $('#plate-text').keyup(function () {
              // ...the rest of your code
          });
      }
  });

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM