WEBデザイン・プログラミング関連の
情報発信を手掛ける STAND4U

HOME > WEB制作 > javascript > jQuery「.clone()」で指定要素をコピーする方法

jQuery「.clone()」で指定要素をコピーする方法

[景品表示法に基づく表記] 本コンテンツにはプロモーションが含まれています。

jQueryの「.clone()」は、指定要素をコピーする事ができるメソッド

今回は、jQueryの「.clone()」について、その使い方をサンプルを交えて解説しよう。

.clone()の機能とは?

.clone()の機能

.clone()は、「指定要素をコピーする」事ができる。

.clone()コピーするだけなので、コピーしたものを使う時はappentTo()insertAfter()などの挿入系のメソッドを使って貼り付けて利用する。

appentTo()insertAfter()をおさらいしたい方はこちらの記事どうぞ。

.clone()の構文

.clone()の構文は次のような記述となる

$("セレクタ").clone(論理値);

この記述で$("セレクタ").で指定した要素をコピーする事ができる。論理値とは「true or false」の真偽値を指し、引数にtrueの論理値を入れる事で、元の「イベントハンドラ」を引き継ぐ事ができる。(イベントハンドラとは、イベントによって発生する「命令内容」を指す)

指定しない場合はデフォルト値のfalseが適用され、単純に指定した「jQueryオブジェクト」だけをコピーする事になる。

.clone()の使用例

たとえば次のようなHTMLがあったとする

HTML
<button id="test">コピー</button>
<div></div>
jQuery
$(function(){
  $("#test").on("click",function(){
    $(this).clone(true).appendTo("div");
  });
});

この例は、ボタンをクリックする事で、divの中に押したボタンそのものをコピーして配置する機能。.clone(true)のように引数にtrueと入れているので「コピーしてdiv内に貼り付ける」というイベントハンドラ自体もコピーされたので、複製したボタンをクリックしても、さらに同じようにボタンが複製される事になる。

この例ではコピーしてそのままdiv内に貼り付けたが、次のように一旦変数に格納しても良いだろう。

var copy = $(this).clone(true);

codepenで動きを確認してみよう。

See the Pen clone() by stand4u (@stand4u) on CodePen.

ボタンをクリックすると、複製される事と、複製したボタンをクリックしても、同様に複製される事が確認できるだろう。

.clone()の使い所

.clone()はさまざまな利用用途があるが、「カルーセルの画像のスライダー」の無限ループを作るのにも利用できる。

上の図のような「10個の画像中、3つだけ見えているスライダー」を作るとする。

html的にはシンプルに10個の画像が並んでいるだけで良いのだが、01が見えている状態で「左の矢印」を押した場合や、「右の矢印」を押しつづけて10個目が見えた後に、最初の1つ目の画像をループしたように見せる方法としてclone()を利用する方法がある。

仕組みだけ解説すると、矢印を押すと同時に、11個目に「1つ目の画像コピーして配置」した上で、元々ある1つ目の画像remove()などで削除する事で、11個目に1個目の画像が移動するような仕組みを作る事ができる。

もっとスマートなやり方もあるかもしれないが、こんな感じでclone()を応用してみてはいかがだろうか?

フロントエンドスキルをもっと早く・簡単にマスターしたい方へ!

JavaScriptやCSS・Sassなどフロントエンド学習は、初心者が「独学」で完全マスターするには半年以上かかり、相当根気よくやらないと挫折してしまうか、ライバルに出遅れてしまう…。

短期間でフロントエンド・WEBデザインをマスターするには?

私の経験だが、手軽なオンラインスクールを利用した方が圧倒的に早かった。独学だと「何からどこまで勉強すれば良いかわからない」ものを、これだけ学習すればOKというポイントをおさえた教科書で学習しながら、わからない点を質問し放題なので、多少の出費は必要だが2ヶ月程度でサクッと学べたので逆に経済的だった!(実際に私がオンラインスクールを受講して体感

では「オススメはどのスクール?」とよく聞かれるのだが、たった1つのおすすめスクールがある訳でなく、その人によって最適なスクールが違う

スクール選びのポイント
  • 学習スタイルが自分に合っているか?
  • 低価格でコスパの良い学習料金か?
  • 講師に質問しやすい環境か?
  • 無料体験できるスクールか?

数あるスクールの中から、実際に受講してわかった事や現役プロならでは目線で厳選・比較したこちらの記事「現役プロ比較!短期 「WEBデザインスクール12校」おすすめランキング!」を参考に自分に合ったスクールを探そう↓

jQuery「.clone()」で指定要素をコピーする方法のまとめ

以上が、jQueryで「.clone()」で指定要素をコピーする」方法でした。

その他のjQueryメソッドについて確認したい方は、jQueryメソッドを一覧で解説したこちらの記事を確認しておこう!


※当記事の掲載内容は執筆現在の個人の見解・調査によるもので、動作・サービス等を保証するものではありません。最新情報は各公式サイトでご確認頂き、購入・契約・データ作成等はご自身の判断・責任でお願いします。 免責事項

関連記事

この記事を書いた人

編集長

WEBデザイン・グラフィックデザイン歴:約18年、HTMLコーディング、jquery、wordpress、イラストなど本業とし、WEBデザインコンサル・プログラミング・ライティング等にも勤しんでいます

プロフィールはこちら

Twitter @stand_4u_ をフォロー

新着記事