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

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

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

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

Q&A

解決済

2回答

3334閲覧

JavascriptでHTMLのテーブル内の指定箇所にある指定文字を全て置き換えたい

退会済みユーザー

退会済みユーザー

総合スコア0

JavaScript

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

0グッド

0クリップ

投稿2020/04/21 02:18

編集2020/04/21 04:35

テーブル内の指定箇所にある指定文字を全て置き換えたいです。

以下やってみた事

HTML

1<table id= "test"> 2 <tbody> 3 <tr> 4 <td>名前</td><td>年齢</td><td>性別</td> 5 </tr> 6 <tr> 7 <td>A</td><td>11</td><td name="a">男性</td> 8 </tr> 9 <tr> 10 <td>B</td><td>15</td><td name="a">男性</td> 11 </tr> 12 <tr> 13 <td>C</td><td>13</td><td name="a">男性</td> 14 </tr> 15 <tr> 16 <td>C</td><td>17</td><td name="a">女性</td> 17 </tr> 18 </tbody> 19</table>

JavaScript

1function getRowCol(){ 2 var row = test.rows.length; 3 4 for (var i = 0; i < row; i++) { 5 var Name = document.getElementsByName('a')[i].innerHTML; 6 Name = Name.replace('男', '女').replace('性', ''); 7 document.getElementsByName('a')[i].innerHTML = Name; 8 } 9 }

テーブルのname属性aの部分で、「男」という文字は「女」、「性」と言う文字は空欄(非表示)にし、最終的に性別列は全て「女」としたいのですが上手くいきません。

どうすれば文字を置き換えることができるのでしょうか?

お手数おかけいたしますが、どなたかご教授頂けますとありがたいです。

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

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

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

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

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

guest

回答2

0

ベストアンサー

全部同じにするなら置換する必要すらないのでは。

js

1document.querySelectorAll( 'td[name="a"]' ).forEach( td=> { 2 td.innerHTML = '女'; 3} ); 4```**動くサンプル:**[https://jsfiddle.net/5uzLpe48/](https://jsfiddle.net/5uzLpe48/) 5 6--- 7 8【Document.querySelectorAll() - Web API | MDN9[https://developer.mozilla.org/ja/docs/Web/API/Document/querySelectorAll](https://developer.mozilla.org/ja/docs/Web/API/Document/querySelectorAll)

投稿2020/04/21 05:30

kei344

総合スコア69458

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

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

退会済みユーザー

退会済みユーザー

2020/04/21 05:50

ご回答頂ありがとうございます。 また、説明足らずで申し訳ありません。 記載したものはわかりやすく簡略化するために性別欄を男性、女性としていますが、実際使用する物は色んな文字列の中から指定した文字のみ指定の文字に置き換える、という動きをさせたいので、全てを女にするとは少し違ってきます。 例><tr><td>りんご!</td></tr> <tr><td>ばなな!</td></tr> <tr><td>みかん!</td></tr>       ↓ <tr><td>りんご?</td></tr> <tr><td>ばなな?</td></tr> <tr><td>みかん?</td></tr> といった感じです。
退会済みユーザー

退会済みユーザー

2020/04/21 06:42

大変失礼致しました。 querySelectorAllを使用すればfor文を使用せずにreplaceで全て置き換えることが可能なのですね。 ありがとうございます。 本当に助かりました。 お手数をおかけいたしました。
guest

0

getRowCol();

投稿2020/04/21 05:27

Yousuck

総合スコア349

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問