質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

3回答

4146閲覧

liタグを1つだけ取得し、HTMLの中から削除したい

scoa

総合スコア66

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2016/11/01 11:18

編集2016/11/22 01:51

いつもお世話になっております。

liタグを1つだけ取得し、HTMLの中から削除したいです。
取得したliタグは、別の場所(例えば違うulタグの中)で使用したいのですが、
どのようにすれば良いのでしょうか。


■HTML(jQueryで生成しているため、改行なしで繋がっている状態)

<ul id="hoge">**<li><img src="img/1.png" alt="1"></li><li>**<img src="img/2.png" alt="2"></li><li><img src="img/3.png" alt="3"></li></ul>

■下記のみを取得して、HTMLの中から削除したい
<li><img src="img/1.png" alt="1"></li><li>
※取得したliタグは別の場所で使用する

■取得の条件
id="hoge"のulタグの中にある、1番目のliタグ(<li></li>)を1つだけ取得
※必ず1番目にalt="1"がくるとは限らない。


恐れ入りますが、
ご教示の程よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yambejp

2016/11/01 11:24

とりだす条件を明記してください
scoa

2016/11/01 11:32

【条件】<li>~</li>を1つだけ取り出す でよろしいでしょうか…。
yambejp

2016/11/01 11:37

HTML上にある全てのLIの中の最初の1つという意味でしょうか?
scoa

2016/11/02 01:04

言葉足らずで申し訳ございません。質問内容に「取得の条件」を追記いたしました。
退会済みユーザー

退会済みユーザー

2016/11/04 04:16

src="img/1.png" となっているものを削除したいのか、alt="1" となっているものを削除したいのかが読み取れません。
guest

回答3

0

再利用するなら.detach()の方がいいのかもしれません。

javascript

1var li = $('li:has(img[alt="1"])') 2li.on('click', function(){alert('click')}) //removeメソッドだとこのクリックイベントは消えます。 3li.detach(); 4$('#fuga').append(li);

The .detach() method is the same as .remove(), except that .detach() keeps all jQuery data associated with the removed elements. This method is useful when removed elements are to be reinserted into the DOM at a later time.

.detach() | jQuery API Documentation

また、即座に再利用するなら.append()で移動した方が楽ですね。
https://jsfiddle.net/9z3m6j2d/

投稿2016/11/02 02:08

Lhankor_Mhy

総合スコア36115

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

scoa

2016/11/04 01:04 編集

ご回答ありがとうございます。 またしても説明不足で大変申し訳ございませんが、 必ず1番目に「alt="1"」がくるとは限りません…。 ですので、「1番目の<li>~</li>を取得」という形にしたいです。
guest

0

とりあえず先頭のliを削除する

javascript

1$(function(){ 2 $('#hoge li').eq(0).remove(); 3}); 4

投稿2016/11/01 11:53

編集2016/11/02 01:14
yambejp

総合スコア114839

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yambejp

2016/11/02 01:15

id=hoge内の先頭のliを削除するように修正しておきました
guest

0

ベストアンサー

javascript

1$(function(){ 2 $('#hoge li:first').remove(); 3});

「◯◯の子要素」の様々な書き方はこの動画が勉強になります。
http://dotinstall.com/lessons/basic_jquery_v2/25204

投稿2016/11/04 04:09

hibikikudo

総合スコア238

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問