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

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

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

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

Q&A

解決済

2回答

2715閲覧

jsでhtmlの指定タグの指定id属性を{ 部分一致で }取得したい。

momolength

総合スコア62

JavaScript

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

0グッド

1クリップ

投稿2021/07/13 11:54

補足:実際は可変値でforeachで回しています。今はわかりやすいよう固定値に設定しています。

$num = 1; $cnt = 1; <div id="test_div_<?php echo $num; ?>_<?php echo $cnt; ?>">

悩み1
こうなっている場合、jsでtest_div_となっている部分で検索をかけて、id値全て取得したいんですが、やり方はありますか?
getelementbyidだと全て(test_div_1_1)と入力しなければならないので困っています。

悩み2

$div_id = $('#test_div_' + num + '_' + cnt);

numとcntを別々で取得してから、こんな感じに取得できないですか。
そうなると、numとcntを取得...の部分がまた謎です。

何かやり方はありますか?

やりたいことは、test_div_とついているdivのid値を全て取得したい。

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

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

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

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

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

yambejp

2021/07/13 12:31

> id値を全て取得したい test_div_1_1を取得したいのか、[1,1]を取得したいのかちょっと曖昧です
momolength

2021/07/13 13:15

遅くまでお疲れ様です。 明日もう一度整理して送りますが、そのままお答えすると「test_div_1_1」のほうです。 一括で取得できるんですかね。 numとcntわけずとも。 回答もありがとうございます。明日見ます。すいません。
guest

回答2

0

ベストアンサー

javascript

1<div id="test_div_1_1">1_1</div> 2<div id="test_div_123_456">123_456</div> 3<div id="test_div_1_dummy">dummy</div> 4<script> 5const res=[...document.querySelectorAll('[id]')].map(x=>x.id).filter(x=>/^test_div_\d+_\d+$/.test(x)).map(x=>(y=x.match(/^test_div_(\d+)_(\d+)$/),[y[1],y[2]])); 6console.log(res); 7</script> 8

投稿2021/07/13 12:05

yambejp

総合スコア116724

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

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

momolength

2021/07/13 23:34

ありがとうございます。 >res=[...document.querySelectorAll すいません、この・・・はどういった意味でしょうか?
yambejp

2021/07/14 00:03

> [...document.querySelectorAll('[id]')] idという属性をもった要素すべてを配列に設定するという意味です
momolength

2021/07/14 00:16

「...」も含めてなんですね...。調べ方悪かったようです。ありがとうございます。 他のも調べて見てみます。
momolength

2021/07/14 00:23

Uncaught TypeError: /^div_test_\d+_\d+$/.test is not a function と出てしまいましたね。
yambejp

2021/07/14 00:32

> Uncaught TypeError 環境はなんでしょう? 普通にやればコピペでidにある数値だけ拾えるはずです
momolength

2021/07/14 02:20

ちょっと挿入する場所が間違っており、正しい場所に入れたところ認識されました。 数字のみの認識であっているので、maisumakunさんの回答よりこちらを選ばせていただきました。結果もこちらのほうが見やすかったです。 大変失礼しました。
guest

0

jsでtest_div_となっている部分で検索をかけて、id値全て取得したいんですが、やり方はありますか?

前方一致セレクタを使えば手早いです。

javascript

1const elements = document.querySelectorAll('[id^="test_div_"]'); 2const ids = [...elements].map(elem => elem.id);

投稿2021/07/14 00:27

maisumakun

総合スコア146018

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

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

momolength

2021/07/14 00:52

const elements = document.querySelectorAll('[id^="test_div_"]'); まずこれで取得できたんですね...。 これをidsの中でって感じですね。わかりやすいです。
yambejp

2021/07/14 01:04

命題のように後ろに数値がくるかどうかわからないので むしろ非効率かなと・・・ (私の回答につけたようなダミーがひっかかる)
maisumakun

2021/07/14 01:06

「jsでtest_div_となっている部分で検索をかけて」とあったので、ダミーのものも引っかかってもいいと判断しました。
yambejp

2021/07/14 01:09

私も最初はそうおもったのですが「numとcntを取得」という表現が 気になったので・・・
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問