JavaScriptで部分一致を使いこなす5つの方法

JavaScript部分一致の解説とサンプルコードJS
この記事は約8分で読めます。

 

【サイト内のコードはご自由に個人利用・商用利用いただけます】

この記事では、プログラムの基礎知識を前提に話を進めています。

説明のためのコードや、サンプルコードもありますので、もちろん初心者でも理解できるように表現してあります。

基本的な知識があればカスタムコードを使って機能追加、目的を達成できるように作ってあります。

※この記事は、一般的にプロフェッショナルの指標とされる『実務経験10,000時間以上』を凌駕する現役のプログラマチームによって監修されています。

サイト内のコードを共有する場合は、参照元として引用して下さいますと幸いです

※Japanシーモアは、常に解説内容のわかりやすさや記事の品質に注力しております。不具合、分かりにくい説明や不適切な表現、動かないコードなど気になることがございましたら、記事の品質向上の為にお問い合わせフォームにてご共有いただけますと幸いです。
(送信された情報は、プライバシーポリシーのもと、厳正に取扱い、処分させていただきます。)

はじめに

この記事を読めば、JavaScriptで部分一致を使いこなすことができるようになります。

部分一致とは、ある文字列が別の文字列の一部に含まれているかどうかを調べる方法です。

JavaScriptで部分一致を使いこなすことで、検索機能やオートコンプリート機能などを実装する際に役立ちます。

この記事では、部分一致の基本や使い方、応用例をサンプルコード付きで解説し、注意点やカスタマイズ方法も紹介します。

どんなことが解決できるか明確にすることで、JavaScript初心者でも安心して読み進めることができます。

●部分一致の基本

部分一致とは、ある文字列が別の文字列の一部に含まれているかどうかを調べる方法です。

JavaScriptでは、主に文字列の検索や配列内の要素検索などで部分一致が使われます。

部分一致を実現するためには、文字列のメソッドや正規表現が用いられます。

●部分一致の使い方

部分一致を実現する方法はいくつかありますが、ここでは代表的な3つの方法を紹介します。

○サンプルコード1:文字列の検索

このコードでは、indexOfメソッドを使って文字列の部分一致検索を行っています。

この例では、mainStrsearchStrが含まれているかを調べています。

const mainStr = "こんにちは、世界!";
const searchStr = "んにちは";

if (mainStr.indexOf(searchStr) !== -1) {
  console.log("部分一致が見つかりました。");
} else {
  console.log("部分一致が見つかりませんでした。");
}

○サンプルコード2:配列内の部分一致検索

このコードでは、Array.prototype.filter()indexOfメソッドを使って、配列内の要素を部分一致検索しています。

この例では、words配列内にsearchStrが含まれている要素を検索しています。

const words = ["apple", "banana", "cherry", "grape"];
const searchStr = "ap";

const result = words.filter(word => word.indexOf(searchStr) !== -1);
console.log(result); // ["apple", "grape"]

○サンプルコード3:正規表現を使った部分一致検索

このコードでは、正規表現を使って部分一致検索を行っています。

この例では、mainStrsearchStrが含まれているかを調べています。

const mainStr = "こんにちは、世界!";
const searchStr = "んにちは";
const regex = new RegExp(searchStr);

if (regex.test(mainStr)) {
  console.log("部分一致が見つかりました。");
} else {
  console.log("部分一致が見つかりませんでした。");
}

●部分一致の応用例

部分一致は、検索機能やオートコンプリート機能など様々な場面で使われます。

ここでは2つの応用例を紹介します。

○サンプルコード4:検索フォームのオートコンプリート機能

このコードでは、inputイベントリスナーと部分一致検索を使って、検索フォームのオートコンプリート機能を実装しています。

この例では、ユーザーが入力したテキストに基づいて、候補リストを表示しています。

<!DOCTYPE html>
<html lang="ja">
<head>
  <meta charset="UTF-8">
  <title>オートコンプリート機能の実装</title>
  <style>
    #suggestions {
      display: none;
      list-style-type: none;
      padding: 0;
      margin: 0;
      border: 1px solid #ccc;
      background-color: #fff;
    }
    #suggestions li {
      padding: 4px 8px;
      cursor: pointer;
    }
    #suggestions li:hover {
      background-color: #eee;
    }
  </style>
</head>
<body>
  <input type="text" id="search" placeholder="検索...">
  <ul id="suggestions"></ul>

  <script>
    const data = ["apple", "banana", "cherry", "grape", "orange", "pineapple", "strawberry"];
    const search = document.getElementById("search");
    const suggestions = document.getElementById("suggestions");

    search.addEventListener("input", () => {
      const searchText = search.value;
      if (searchText === "") {
        suggestions.style.display = "none";
        return;
      }

      const filteredData = data.filter(item => item.indexOf(searchText) !== -1);
      suggestions.innerHTML = "";

      filteredData.forEach(item => {
        const li = document.createElement("li");
        li.textContent = item;
        suggestions.appendChild(li);
      });

      suggestions.style.display = "block";
    });
  </script>
</body>
</html>

○サンプルコード5:ハイライト表示

このコードでは、正規表現を使って部分一致検索を行い、検索に一致した部分をハイライト表示する方法を紹介しています。

この例では、content内のsearchTextに一致する部分をハイライト表示しています。

const content = "部分一致検索は、文字列や配列内の要素を検索する際に非常に便利です。";
const searchText = "検索";

const regex = new RegExp(`(${searchText})`, "gi");
const highlightedContent = content.replace(regex, "<mark>$1</mark>");

console.log(highlightedContent);
// "部分一致<mark>検索</mark>は、文字列や配列内の要素を<mark>検索</mark>する際に非常に便利です。"

●注意点と対処法

部分一致検索を行う際の注意点として、大文字と小文字の違いによって一致しない場合があります。

この問題を解決するためには、検索対象と検索文字列の両方を小文字または大文字に変換してから比較することが効果的です。

下記のサンプルコードでは、toLowerCase()メソッドを使って文字列を小文字に変換し、部分一致検索を行っています。

const content = "JavaScriptは、大文字と小文字が区別されます。";
const searchText = "小文字";

const lowerContent = content.toLowerCase();
const lowerSearchText = searchText.toLowerCase();

if (lowerContent.indexOf(lowerSearchText) !== -1) {
  console.log("部分一致が見つかりました。");
} else {
  console.log("部分一致が見つかりませんでした。");
}

●カスタマイズ方法

部分一致検索は多くの場面で活用できますが、用途に応じてカスタマイズすることが可能です。

例えば、正規表現を使って検索対象に特定のパターンが含まれているかどうかを調べることができます。

また、検索時に特定の文字列を無視したい場合、検索対象からその文字列を除去してから検索を行うことができます。

まとめ

部分一致検索は、文字列や配列内の要素を検索する際に非常に便利な機能です。

JavaScriptでは、indexOfメソッドや正規表現を使って部分一致検索を実現することができます。

また、応用例として検索フォームのオートコンプリート機能やハイライト表示などがあります。

注意点としては、大文字と小文字の違いによる検索結果の違いがあるため、対処法として文字列を同じケースに変換してから比較することが重要です。

部分一致検索をカスタマイズして、様々なシーンで活用してみてください。