🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
JavaScript

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

Q&A

5回答

1314閲覧

JavaScript forの条件式を変数で定義するには

adddd

総合スコア0

JavaScript

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

0グッド

1クリップ

投稿2021/03/04 16:36

前提・実現したいこと

タイトルの通りです
forの条件式を変数で定義するにはどうしたらいいんでしょうか
var f=0;
var j="i=0;i<10;i++";
var jj="i=10;i<20;i++";
if(f==0){
for(j){
}
f=1;
}else{
for(jj){
}
}
では動きません
上記のような構造の文を書きたいと考えています
forの条件式を変数で出力するのは不可能なんでしょうか?

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

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

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

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

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

maisumakun

2021/03/05 01:26

なぜそのような書き方をしたいのでしょうか? 「趣味的にそう書きたい」のか、それとも「実用的に必要が生じた」のか、どちらでしょうか?
adddd

2021/03/05 01:55

forの条件式をあとから変えたりとできれば、かなり実用的だと思います =興味からの実用という流れになると思います
takasima20

2021/03/05 11:27

ちなみに、ループの中でやる処理は同じって前提なのかな?
guest

回答5

0

javascript

1window.addEventListener('DOMContentLoaded',async()=>{ 2 const loop=async(start,end,step=1)=>Array(parseInt((end-start)/step)+1).fill(null).map((_,x)=>x*step+start); 3 let f=0; 4 console.log("start"); 5 if(f==0){ 6 await loop(0,9).then(console.log); 7 f=1; 8 }else{ 9 await loop(10,19).then(console.log); 10 } 11 console.log("end"); 12});

投稿2021/03/05 00:28

yambejp

総合スコア116661

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

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

adddd

2021/03/05 02:02

未知の書き方です。。。
guest

0

可能か不可能かと言う話であれば、for文全体をevalで囲めば可能です。

JavaScript

1var f = 0; 2var j = "i=0;i<10;i++"; 3var jj = "i=10;i<20;i++"; 4var i; 5if (f==0) { 6 eval(` 7 for(${j}){ 8 console.log(i); 9 } 10 `); 11 f=1; 12} else { 13 eval(` 14 for(${jj}){ 15 console.log(i); 16 } 17 `); 18}

ただし、これは非常に悪い方法です。evalの危険性をレポート用紙3枚にまとめることができないのであれば、絶対にこのようなコードは書いてはいけません。(私は書けるから書いているんですよ!)

実際は変化するところだけを変数として持たせるなどをすればいいだけです。変更されるのは初期値と終わりの値だけなのであれば、例えば、次のようにした方がいいでしょう。

JavaScript

1let f = 0; 2 3const j = {first: 0, last: 10}; 4const jj = {first: 10, last: 20}; 5if (f == 0) { 6 for (let i = j.first; i < j.last; i++) { 7 console.log(i); 8 } 9} else { 10 for (let i = jj.first; i < jj.last; i++) { 11 console.log(i); 12 } 13}

投稿2021/03/04 22:19

raccy

総合スコア21737

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

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

adddd

2021/03/04 23:36

evalの危険性について勉強していきたいと思います 2つ目はforの記述を2回にしていますが、式だけ変えることができれば、 ソースコード内に1回のforの記述で済むと考えたのですが、 それはできないようですね
maisumakun

2021/03/05 02:29

> 2つ目はforの記述を2回にしていますが、式だけ変えることができれば、 ソースコード内に1回のforの記述で済むと考えたのですが、 それはできないようですね いえ、できます。 const cond = f == 0 ? j : jj; としてからfor (let i = cond.first; i < cond.last; i++)で回せばOKです。
guest

0

forの条件式をあとから変えたりとできれば、かなり実用的だと思います

そんな複雑な条件を与えるのであれば、中からbreakするようなコードを書いたほうがやりやすいかと思います。わざわざforの条件部分に詰め込むことではありません。

投稿2021/03/05 02:16

maisumakun

総合スコア145963

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

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

0

js

1let f = 0; 2 3 4let begin = (f == 0) ? 0 : 10 5let end = (f==0) ? 10 : 20 6 7for (let i = begin; i < end; i++) { 8 console.log(i); 9} 10

投稿2021/03/04 23:57

ozwk

総合スコア13551

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

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

adddd

2021/03/05 01:17

こちらのソースで for(i=0;i<10;i++) と for(i=10;i>0;i--) のような変え方はできるんでしょうか?
guest

0

そういう使い方はできません。
文法を無視するような使い方になってますね

投稿2021/03/04 22:13

y_waiwai

総合スコア88038

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問