2017-10-10 14 views
4

通常の文字を入力すると、トルコ文字をフィルタする方法を教えてください。 「GülayGül」という名前をフィルタリングしたいとき、Gul ..などと入力すると表示されません。これをjQueryで回避することは可能ですか?入力フィールドにトルコ文字をフィルタリングします

var item = $('.item'); 
 
    $('input').keyup(function() { 
 
    var valThis = $(this).val().toLowerCase(); 
 
    if (valThis == '') { 
 
     $(item).show(); 
 
    } else { 
 
     $(item).each(function() { 
 
     var text = $(this).text().toLowerCase(); 
 
     var match = text.indexOf(valThis); 
 
     if (match >= 0) { 
 
      $(this).show(); 
 
     } else { 
 
      $(this).hide(); 
 
     } 
 
     }); 
 
    }; 
 
    });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<input type="text" placeholder="Search"> 
 
<div class="item"> 
 
    <h3>John walker</h3> 
 
</div> 
 
<div class="item"> 
 
    <h3>Michael Mayer</h3> 
 
</div> 
 
<div class="item"> 
 
    <h3>Tim Jones</h3> 
 
</div> 
 
<div class="item"> 
 
    <h3>Gülay Gül</h3> 
 
</div>

+1

私のために3試合を返すよ。 @pedram – Vincent1989

答えて

6

あなたはここにthisに基づいてaccent folding.と呼ばれる探しているものをあなたのスクリプトを更新し、私のソリューションです:

Turkish CHARACを交換して

var item = $('.item'); 
 
    $('input').keyup(function() { 
 
    var valThis = $(this).val().toLowerCase(); 
 
    if (valThis == '') { 
 
     $(item).show(); 
 
    } else { 
 
     $(item).each(function() { 
 
     var text = accentsTidy($(this).text().toLowerCase()); 
 
     var match = text.indexOf(valThis); 
 
     if (match >= 0) { 
 
      $(this).show(); 
 
     } else { 
 
      $(this).hide(); 
 
     } 
 
     }); 
 
    }; 
 
    }); 
 
    
 
    accentsTidy = function(s) { 
 
    var map = [ 
 
     ["\\s", ""], 
 
     ["[àáâãäå]", "a"], 
 
     ["æ", "ae"], 
 
     ["ç", "c"], 
 
     ["[èéêë]", "e"], 
 
     ["[ìíîï]", "i"], 
 
     ["ñ", "n"], 
 
     ["[òóôõö]", "o"], 
 
     ["œ", "oe"], 
 
     ["[ùúûü]", "u"], 
 
     ["[ýÿ]", "y"], 
 
     ["\\W", ""] 
 
    ]; 
 
    for (var i=0; i<map.length; ++i) { 
 
     s = s.replace(new RegExp(map[i][0], "gi"), function(match) { 
 
      if (match.toUpperCase() === match) { 
 
       return map[i][1].toUpperCase(); 
 
      } else { 
 
       return map[i][1]; 
 
      } 
 
     }); 
 
    } 
 
    return s; 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<input type="text" placeholder="Search"> 
 
<div class="item"> 
 
    <h3>John walker</h3> 
 
</div> 
 
<div class="item"> 
 
    <h3>Michael Mayer</h3> 
 
</div> 
 
<div class="item"> 
 
    <h3>Tim Jones</h3> 
 
</div> 
 
<div class="item"> 
 
    <h3>Gülay Gül</h3> 
 
</div>

1

あなたはこれを迂回することができますEnglishとter。 regexを使用してトルコ語をフィルタリングし、これらを英語に置き換えると、実際には比較の前にテキストが置き換えられます。

// search filter 
 
    var item = $('.item'); 
 
    var Turkish = { 
 
     Ç: 'C', 
 
     Ö: 'O', 
 
     Ş: 'S', 
 
     İ: 'I', 
 
     I: 'i', 
 
     Ü: 'U', 
 
     Ğ: 'G', 
 
     ç: 'c', 
 
     ö: 'o', 
 
     ş: 's', 
 
     ı: 'i', 
 
     ü: 'u', 
 
     ğ: 'g' 
 
    }; 
 

 

 
    $('input').keyup(function() { 
 
    var valThis = $(this).val().toLowerCase(); 
 
    if (valThis == '') { 
 
     $(item).show(); 
 
    } else { 
 
     $(item).each(function() { 
 
     var text = $(this).text().toLowerCase(); 
 
     
 
var clearTr = text.replace(/Ü|Ç|Ö|Ş|İ|I|Ğ|ç|ö|ş|ı|ü|ğ/gi, function(matched){ 
 
    return Turkish[matched]; 
 
}); 
 
     var match = clearTr.indexOf(valThis); 
 
     if (match >= 0) { 
 
      $(this).show(); 
 
     } else { 
 
      $(this).hide(); 
 
     } 
 
     }); 
 
    }; 
 
    });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<input type="text" placeholder="Search"> 
 
<div class="item"> 
 
    <h3>John walker</h3> 
 
</div> 
 
<div class="item"> 
 
    <h3>Michael Mayer</h3> 
 
</div> 
 
<div class="item"> 
 
    <h3>Tim Jones</h3> 
 
</div> 
 
<div class="item"> 
 
    <h3>Gülay Gül</h3> 
 
</div> 
 
<div class="item"> 
 
    <h3>Derya Uluğ</h3> 
 
</div>

私はこれであなたを助けることはできませんが、私はそれを
+0

をhttps://jqueryui.com/autocomplete/#folding、この機能はデフォルトでビルドしたjQueryのオートコンプリートウィジェットを知っていますか – Optional

+0

@オプションのええ、今何が問題かを調べようとしています。 – Pedram

関連する問題