<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ja">
	<id>https://twiki.yo-net.jp/index.php?action=history&amp;feed=atom&amp;title=JAVA_Script_.next%28%29_.Value_.done%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%9Ffor%E6%96%87</id>
	<title>JAVA Script .next() .Value .doneを使ったfor文 - 版の履歴</title>
	<link rel="self" type="application/atom+xml" href="https://twiki.yo-net.jp/index.php?action=history&amp;feed=atom&amp;title=JAVA_Script_.next%28%29_.Value_.done%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%9Ffor%E6%96%87"/>
	<link rel="alternate" type="text/html" href="https://twiki.yo-net.jp/index.php?title=JAVA_Script_.next()_.Value_.done%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%9Ffor%E6%96%87&amp;action=history"/>
	<updated>2026-04-05T02:05:30Z</updated>
	<subtitle>このウィキのこのページに関する変更履歴</subtitle>
	<generator>MediaWiki 1.38.2</generator>
	<entry>
		<id>https://twiki.yo-net.jp/index.php?title=JAVA_Script_.next()_.Value_.done%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%9Ffor%E6%96%87&amp;diff=1911&amp;oldid=prev</id>
		<title>2022年11月22日 (火) 14:09にYo-netによる</title>
		<link rel="alternate" type="text/html" href="https://twiki.yo-net.jp/index.php?title=JAVA_Script_.next()_.Value_.done%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%9Ffor%E6%96%87&amp;diff=1911&amp;oldid=prev"/>
		<updated>2022-11-22T14:09:55Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;ja&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← 古い版&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;2022年11月22日 (火) 23:09時点における版&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l8&quot;&gt;8行目:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;8行目:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;例えば、&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;例えば、&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;syntaxhighlight lang=&amp;quot;javascript&amp;quot; &lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;inline&lt;/del&gt;&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;syntaxhighlight lang=&amp;quot;javascript&amp;quot;&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;for(var arraydata = arrayobject, countobject = arraydata.next();  &lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;for(var arraydata = arrayobject, countobject = arraydata.next();  &lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;         !countobject.done;&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;         !countobject.done;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Yo-net</name></author>
	</entry>
	<entry>
		<id>https://twiki.yo-net.jp/index.php?title=JAVA_Script_.next()_.Value_.done%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%9Ffor%E6%96%87&amp;diff=1910&amp;oldid=prev</id>
		<title>Yo-net: ページの作成:「JAVA Scriptへ戻る。 == '''概要''' == 　少し高度なfor文の使い方です。for in や for of より直感的ではない仕組みです。   　[https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Generator/next https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Generator/next] によると、next()を使うと、value 実際に使いたい次々に取り出す配列値 と done 終了フラグ…」</title>
		<link rel="alternate" type="text/html" href="https://twiki.yo-net.jp/index.php?title=JAVA_Script_.next()_.Value_.done%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%9Ffor%E6%96%87&amp;diff=1910&amp;oldid=prev"/>
		<updated>2022-11-22T14:09:17Z</updated>

		<summary type="html">&lt;p&gt;ページの作成:「&lt;a href=&quot;/JAVA_Script&quot; title=&quot;JAVA Script&quot;&gt;JAVA Script&lt;/a&gt;へ戻る。 == &amp;#039;&amp;#039;&amp;#039;概要&amp;#039;&amp;#039;&amp;#039; == 　少し高度なfor文の使い方です。for in や for of より直感的ではない仕組みです。   　[https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Generator/next https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Generator/next] によると、next()を使うと、value 実際に使いたい次々に取り出す配列値 と done 終了フラグ…」&lt;/p&gt;
&lt;p&gt;&lt;b&gt;新規ページ&lt;/b&gt;&lt;/p&gt;&lt;div&gt;[[JAVA Script]]へ戻る。&lt;br /&gt;
== '''概要''' ==&lt;br /&gt;
　少し高度なfor文の使い方です。for in や for of より直感的ではない仕組みです。&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
　[https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Generator/next https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Generator/next] によると、next()を使うと、value 実際に使いたい次々に取り出す配列値 と done 終了フラグ を返すという仕組みがあるとのこと。終わったら true だそうです。&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
例えば、&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;javascript&amp;quot; inline&amp;gt;&lt;br /&gt;
for(var arraydata = arrayobject, countobject = arraydata.next(); &lt;br /&gt;
        !countobject.done;&lt;br /&gt;
        countobject = arraydata.next()){&lt;br /&gt;
    … ; &lt;br /&gt;
    var contentvalue= countobject.value;&lt;br /&gt;
    … &lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
　for文はこの形式で構成されます。&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
　例では、初期値の処理が二つになります。配列や連想配列構造のオブジェクトarrayobjectをarraydataに受け取り、この値に対してarraydata.next()を呼び出すたびに次の配列値へと移動しますが、最初の値の取り出しでもarraydata.next()が必要なので、実行して、実際に使う変数値として、countobject に保持させます。これがfor文の初期動作です。終了条件は、実際に使う値の countobject のメンバ関数 done(ダン) を監視すればよいことになります。最後の値を処理したら、true になります。&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
　なので、終了条件は !countobject.done となります。&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
　そして、次の値を実際に使用する変数 countobject に代入しつつも、arraydata.next() を呼び出せばいいです。for文の中では実際に使う値を、contentvalue = countobject.valueのように取り出すことをするでしょう。実際、mathjax でも、実にオーソドックスに配列の値を使ったfor文を処理しています。&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
　一方で、もうちょっと変わった連想配列の繰り返し処理中で特殊なfor文(for of：キー値のみ取り出し/for in：値の取り出し)は使っていないようです。for in だと関数内で追加で定義宣言(これをよくプロトタイプ関数と言っています。)した関数が配列の中の要素として使われるので、値が関数でないかを確認しなくてはいけなくなったりします。複雑なプログラムでは実は意外と使いにくいfor in。for of で配列値を指定した場合はキーではなく、配列値が使えます。&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;javascript&amp;quot; inline&amp;gt;for(var val 【of/in】 Array){…}&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
　直感的な for in や for of に比べると難しい .next() を利用したfor文ですが、覚えておくとよいでしょう。&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
　&lt;br /&gt;
&lt;br /&gt;
[[JAVA Script]]へ戻る。&lt;/div&gt;</summary>
		<author><name>Yo-net</name></author>
	</entry>
</feed>