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

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

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

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

Q&A

解決済

4回答

451閲覧

【Javascript】配列の中身を定数名として定義する方法

flandre

総合スコア10

JavaScript

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

0グッド

0クリップ

投稿2021/09/13 11:30

配列の中身を定数名にしたいのですが、以下のようなコードでは上手くいきませんでした

Javascript

1const itemName = [apple, orange, grape]; 2for (let i = 0; i < itemName.length; i++) { 3 const itemName[i] = document.createElement('div'); 4}

定数名appleのdiv要素、定数名orangeの〃、定数名grapeの〃をfor文を用いて作るにはどうすればいいのでしょうか

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

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

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

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

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

think49

2021/09/13 13:30

「期待する結果」を具体的に書いてください。
think49

2021/09/13 13:37

> const itemName = [apple, orange, grape]; このコードは変数 apple の値、変数 orange の値、変数 grape の値が代入されています。 apple, orange, grape の名前は itemName の中にありません。
guest

回答4

0

配列の中身を定数名にしたいのですが

よほど理由がない限り、やるべきではありません。それぞれの値をキーにした連想配列のほうが妥当かと思います。

投稿2021/09/13 12:00

maisumakun

総合スコア145208

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

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

flandre

2021/09/13 15:05

回答ありがとうございます 大人しくそうしようと思います
guest

0

あくまでも先に配列の設定が必要なのでしょうか?

javascript

1[apple,orange,grape]=Array(3).fill(null).map(()=>document.createElement('div')); 2console.log(apple);

投稿2021/09/13 12:51

yambejp

総合スコア115012

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

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

flandre

2021/09/13 15:12

まだ学び始めて日が浅く、fill()もmap()も初めて知りました。こんな便利なメソッドがあったとは… 回答ありがとうございます
guest

0

const

定数名appleのdiv要素、定数名orangeの〃、定数名grapeの〃をfor文を用いて作るにはどうすればいいのでしょうか

今一つ目的が見えませんが、

JavaScript

1'use strict'; 2const array = []; 3 4for (let i = 0; i < 3; i++) { 5 array[i] = document.createElement('div'); 6} 7 8const apple = array[0], orange = array[1], grape = array[2]; 9console.log(apple, orange, grape);

定数を使うだけなら、for 文は不要です。

JavaScript

1'use strict'; 2const apple = document.createElement('div'), orange = apple.cloneNode(false), grape = apple.cloneNode(false); 3console.log(apple, orange, grape);

ConstMap

まだ要件がはっきり見えませんが、期待しているのは下記コードのような動作ですか。

HTML

1<script src="./const-map-0.1.0.js"></script> 2<script> 3const keys = ['apple','orange','grape']; 4const fruitMap = new ConstMap; 5 6for (let i = 0, l = keys.length; i < l; ++i) { 7 fruitMap.set(keys[i], document.createElement('div')); 8} 9 10console.log(fruitMap.values()); // [div, div, div] 11console.log(fruitMap.get('apple')); // <div></div> 12console.log(fruitMap.set('apple', 'foo')); // DefinitionError: Identifier 'apple' has already been declared 13</script>

Re: jjj001 さん

投稿2021/09/13 12:22

編集2021/09/13 13:32
think49

総合スコア18170

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

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

flandre

2021/09/13 15:09

いずれも自分が実現したかった動作です 回答ありがとうございます
think49

2021/09/13 15:23

要件をはっきりさせてほしかったのですが…。 定数と書いていたので、再代入不可機能が必要と考え、class ConstMapを作りましたが、連想配列で要件を満たせるということは「再代入不可」は要件に入ってなかったのですね。 質問時点で要件は必要十分に書くようお願いします。
flandre

2021/09/13 15:44

自分の言葉足らずでお手数をおかけしてしまい申し訳ありません 以後はもっと具体的に目的を書こうと思います
guest

0

ベストアンサー

連想配列を使いましょう。

const itemName = ['apple', 'orange', 'grape']; let items = {}; for (let i = 0; i < itemName.length; i++) { items[itemName[i]] = document.createElement('div'); } items['apple'].textContent = 'apple'; document.body.appendChild(items['apple']);

どうしてもやろうと思うならevalでできます。
が、maisumakunさんのおっしゃる通り、やるべきではありません。

const itemName = ['apple', 'orange', 'grape']; let items = {}; for (let i = 0; i < itemName.length; i++) { eval(`${itemName[i]} = document.createElement('div');`); } apple.textContent = 'apple'; document.body.appendChild(apple);

投稿2021/09/13 12:11

編集2021/09/13 12:17
itagagaki

総合スコア8402

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

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

flandre

2021/09/13 15:06

回答ありがとうございます 確かに素直に連想配列を使った方が良いですね evalという関数は今初めて知りました。便利な一方で脆弱性が高いんですね…
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問