• HOME > 
  • JavaScript > 
  • jQueryで文字列の置換を行う方法【replaceメソッド...

jQueryで文字列の置換を行う方法【replaceメソッドの使い方】

投稿日:

このページにはGoogleアドセンス広告とアフィリエイト広告が含まれています。

カテゴリー記事のアイキャッチ画像
広告
広告

文字列の置換とは?

WEBサイトやWEBサービスの制作においては、ユーザーのアクションなどに応じて、元のHTMLに記述された文字列を別の文字列へと書き換えたい場面があります。

このページでは、JavascriptとそのライブラリであるjQueryを使用して文字列の置換を行う方法について解説します。

文字列の置換には、Javascriptの「replace()」メソッド、jQueryの「replaceAll()」メソッドを使用します。

replaceメソッドの使い方

replaceメソッドは次のように記述して使用します。

replaceメソッドの書き方

repalceメソッドを使えば、テキストのみ文字列の置換だけでなく、HTMLを含んだ文字列の置換も行うことが可能です。

なおrelapceはJavascriptのメソッドですのでjQueryを読み込んでいなくても使用することができますが、ここではreplace以外でjQueryのメソッドを使用していますので、参考にされる場合は事前にCDNなどでjQueryを読み込ませておいてください。

テキストを置き換える

まずは基本となるテキストの置換について解説します。

次の例では、「こんにちわ、太郎さん!」というテキストの名前の部分を別の文字列に置き換えるようにしています。

HTML

<div id="target">こんにちわ、太郎さん!</div>

jQuery

$(function(){
    var target = $("#target").text();
    var result = target.replace("太郎","花子");
    $("#target").text(result);
});

プレビュー

こんにちわ、太郎さん!

コードの解説

上記のコードについてひとつひとつ解説していきます。

2行目まずはじめに、対象となる書き換えたいテキストを取得する必要があります。

テキストの取得は、「text()」メソッドで行います。id「#target」という要素のテキストを取得します。

3行目続いて、取得したテキストの中の「太郎」という文字列をreplaceメソッドを使って「花子」という文字列に置き換えます。

4行目最後に再度text()メソッドを使って文字列の置き換えを行ったテキストをid「#target」という要素に書き換えれば完了です。

replaceメソッドはあくまでも文字列の置換を行うメソッドであり、ページ上に表示させるためにはtextメソッドなど他のメソッドを使う必要があります。

HTMLを置き換える

HTMLを含んだ文字列も同じ手順で置き換えることができます。

HTMLの取得には「html()」メソッドを使用します。

HTML

<div id="target">こんにちわ、<span>太郎</span>さん!</div>

jQuery

$(function(){
    var target2 = $("#target2").html();
    var result2 = target2.replace("<span>太郎</span>","<h3>花子</h3>");
    $("#target2").html(result2);
});

プレビュー

こんにちわ、太郎さん!
リンク先のサムネイル
jQueryのtext()の使い方【取得・追加・変更・削除の方法】

text()メソッドを使えば、ユーザーのアクションに応じて表示するテキストを切り替えるといった処理を行うことができます。html()メソッドは要素のHTMLタグを含んだテキストの追加や変更などを操作できます...【もっと読む】

ここで注意が必要なのは、上記の方法の場合に置換が行われるのは最初にヒットした文字列のみであるという点です。

下記のように2つ目以降の文字列は置換されません。

HTML

<div id="target">こんにちわ、太郎さん!太郎さんの今日の予定は何ですか?</div>

jQuery

$(function(){
    var target3 = $("#target3").text();
    var result3 = target3.replace("太郎","花子");
    $("#target3").text(result3);
});

プレビュー

こんにちわ、太郎さん!太郎さんの今日の予定は何ですか?

一致した文字列を全て置き換えたい場合は次項で説明する方法で行います。

一致した文字列を全て置き換える

一致した文字列を全て置き換えたい場合は次のように記述します。

一致した文字列を全て置き換える書き方

先程の例も次のようにすれば一致した文字列を全て置き換えることができます。

HTML

<div id="target">こんにちわ、太郎さん!太郎さんの今日の予定は何ですか?</div>

jQuery

$(function(){
    var target4 = $("#target4").text();
    var result4 = target4.replace(/太郎/g,"花子");
    $("#target4").text(result4);
});

プレビュー

こんにちわ、太郎さん!太郎さんの今日の予定は何ですか?

複数の箇所(要素)で一致した文字列を全て置き換える

複数の箇所(要素)で文字列の置換を行いたい場合は、記述の方法を変更しないと正しく置換が行えません。複数の箇所(要素)で文字列の置換を行う時は、each()メソッドを利用します。

HTML

<div class="test">こんにちわ、太郎さん!太郎さんの今日の予定は何ですか?</div>
<div class="test">こんばんわ、太郎さん!太郎さんの明日の予定は何ですか?</div>

jQuery

$(function(){
    $(".test").each(function(){
        var test = $(this).text();
        $(this).text(test.replace(/太郎/g,"花子"));
    });
});

プレビュー

こんにちわ、太郎さん!太郎さんの今日の予定は何ですか?
こんばんわ、太郎さん!太郎さんの明日の予定は何ですか?

正規表現を使って置き換える

replaceメソッドでは、正規表現を用いて特定の条件を満たした文字列を置き換えるようにすることも可能です。

下の例では、置き換えを行う対象を[0-9]とすることで全ての数字を「*」に置き換えています。

HTML

<div id="target5" class="target">パスワードは12345です。</div>

jQuery

$(function(){
    var target5 = $("#target5").text();
    var result5 = target5.replace(/[0-9]/g,"*");
    $("#target5").text(result5);
});

プレビュー

パスワードは12345です。

アルファベット小文字の場合は[a-z]、大文字の場合は[A-Z]と記述します。

replaceWithメソッドとreplaceAllメソッドの使い方

ここまで説明してきたreplaceメソッドに対して、replaceWithメソッドとreplaceAllメソッドはjQueryのメソッドです。

replaceメソッドよりもダイレクトかつ簡潔に要素の置き換えを行うことができます。

replaceWith

replaceWithとreplaceAllの違いは、記述の際にセレクタと置き換える文字列の順序が逆になるという点です。

replaceWithの書き方

HTML

<div id="target6" class="target">こんにちわ、太郎さん!太郎さんの今日の予定は何ですか?</div>

jQuery

$(function(){
    $("#target6").replaceWith('<div id="target6" class="target">こんにちわ、花子さん!花子さんの今日の予定は何ですか?<div>');
});

プレビュー

こんにちわ、太郎さん!太郎さんの今日の予定は何ですか?

replaceAll

replaceAllの書き方

HTML

<div id="target7" class="target">こんにちわ、太郎さん!太郎さんの今日の予定は何ですか?</div>

jQuery

$(function(){
    $('<div id="target6" class="target">こんにちわ、花子さん!花子さんの今日の予定は何ですか?<div>').replaceAll("#target7");
});

プレビュー

こんにちわ、太郎さん!太郎さんの今日の予定は何ですか?

replaceWithとreplaceAllは、文字列の置き換えというよりも要素の置き換えという意味合いの方が大きいかもしれません。

まとめ

以上がJavascript(jQuery)で文字列を置き換える方法です。replaceメソッドを使いこなすことができれば、ユーザーがフォームに入力した内容によって表示するテキストを変更するなど、操作に応じた動的なサイトを作ることができます。

広告
広告

関連する記事

サムネイル

JSのclassList.toggleでクラスの付け外しを行……

2024年09月04日
classList.toggleとは? まず「classList」とは要素のクラス属性の情報を参照するプロパティで、「classList.add()」や「cla […]
サムネイル

JSで要素が特定のクラスを持つか調べる【classList.……

2024年09月04日
JSで要素が特定のクラスを持つか調べるには? JavaScriptで要素が特定のクラスを持つか調べるには「classList.contains」を使います。 「 […]
サムネイル

JSで文字列の中の任意の位置に別の文字を挿入する【slice……

2024年09月04日
JavaScriptに文字列の中の任意の位置に別の文字を挿入するにはslice()メソッドを利用します。sliceは特定の文字列の任意の位置から任意の文字数分を切り出すメソッドで、これを使って対象の文字列を一旦分解し、挿入したい文字と一緒新しい文字列としてくっつけ直します。
サムネイル

【数値のゼロ埋め】JSのpadStart(padEnd)メソ……

2024年09月04日
JavaScriptのpadStartは対象の文字列が任意の桁数になるまで、その先頭から指定した文字で文字埋めを実行するメソッドです。第一引数に最終的な桁数、第二引数に埋める文字を指定します。
サムネイル

JSのsetIntervalで一定時間ごとに繰り返し処理を実……

2024年08月01日
JSのsetIntervalとは? 業務においてJavaScriptを使って一定時間おきに繰り返し処理を実行させたい場面があり、これまで大まかにしか理解していな […]
サムネイル

JSのsetTimeoutで指定した時間後に処理を実行させる……

2024年08月01日
setTimeout()は、指定した時間が経過したら処理を一度だけ実行するといったタイマーのような設定ができる関数です。一定間隔で処理を繰り返すsetIntervalと異なり、処理が一回しか実行されない点が特徴です。停止させる場合はclearTimeoutを使います。
サムネイル

JSでセレクト値が変更されたらフォームを送信を実行する方法【……

2024年07月02日
ユーザーがセレクトボックスの値を変更したタイミングでフォームの送信を実行するという処理を実装する機会があったので、その方法を備忘録として残しておきます。