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

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

ただいまの
回答率

90.37%

  • JavaScript

    18784questions

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

  • jQuery

    7555questions

    jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

  • Monaca

    1048questions

    「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

  • Cordova

    450questions

    Cordovaは様々なデバイスで使うことができるオープンソースなモバイル用開発プラットフォームです。開発者に各デバイスの元のプラットフォームで開発する必要をなくし、HTML・JavaScript・CSSなどの一般的なウェブのテクノロジーを使ってすべてのデバイスで展開することができるモバイルのアプリケーションを生成することを可能にします。

連番の付いたプロパティの内容を繰り返し処理で取得したい

解決済

回答 6

投稿

  • 評価
  • クリップ 0
  • VIEW 1,041

agepan

score 54

JavaScriptのプロパティ(オブジェクト)として以下の連番が振られたデータがあるときに、for文のような繰り返し処理を使ってまとめて内容を取得したいのですが、どのようにコードを書くことで実現できるでしょうか?

よろしくお願いいたします。

var test = {
  'koumoku_1': 'あああ',
  'koumoku_2': 'いいい',
  'koumoku_3': 'ううう'
}

for (var i = 0; i < test.length; i++) {
  console.log(test.koumoku_[i + 1]); // これではデータにアクセスできない
} 

// 現状、同じコードを連番分だけ複製させて処理させていますが、シンプルなコードを実現したいです
console.log(test.koumoku_1);
console.log(test.koumoku_2);
console.log(test.koumoku_3);
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 6

+7

オブジェクトはfor-in構文でループ可能です.

var test = {
  'koumoku_1': 'あああ',
  'koumoku_2': 'いいい',
  'koumoku_3': 'ううう'
}
for (var i in test) {
  console.log(test[i]);
} 


NOTE:
Object.entriesメソッドと組み合わせるとfor-of構文が使えるようになります.

var test = {
  'koumoku_1': 'あああ',
  'koumoku_2': 'いいい',
  'koumoku_3': 'ううう'
}
for(var [key, val] of Object.entries(test)){
    console.log(val);
}

NOTE:
一般のオブジェクトにはlengthプロパティがありませんから, 普通のループ処理はできません. もしも数値部が連続しており, その範囲が判っているのであれば次のように記述することが可能です.

var test = {
  'koumoku_1': 'あああ',
  'koumoku_2': 'いいい',
  'koumoku_3': 'ううう'
}
var [begin, end] = [1, 3];
for (var i = begin; i <= end; i++) {
  console.log(test[`koumoku_${i}`]);
} 

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/04/12 09:49

    ありがとうございます!
    色々な方法をご教授頂きありがとうございます。これらの方法は今後もよく使えると思いますので勉強させていただきます!

    キャンセル

+5

var test = {
  'koumoku_1': 'あああ',
  'koumoku_2': 'いいい',
  'koumoku_3': 'ううう'
}

$.each(test,function(i,k){
  console.log(i+' : '+k);
});


簡単にまわしてみました。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/04/12 09:48

    ご回答ありがとうございます!
    このような方法でも値を取得できるのですね。ありがとうございました。

    キャンセル

+3

すでに変数の連番についてはずばり回答が揃ったようなので
連番だけが目的ならこうする手もあるでしょう。

var test = {
  'koumoku':[
    'あああ',
    'いいい',
    'ううう',
    ],
};

for (var i = 0; i < test.koumoku.length; i++) {
  console.log(test.koumoku[i]);
} 
console.log(test.koumoku[0]);
console.log(test.koumoku[1]);
console.log(test.koumoku[2]);


※連番=参照に順番をもたせたいなら配列で指定し、
連番の最初は1ではなく0が処理しやすい

 蛇足

koumokuにつく数値が何から始まって何でおわるかわからなかったり
ゴミデータがあったりする場合も想定するとこう

var test = {
  'koumoku_102': 'いいい',
  'koumoku_103': 'ううう',
  'koumoku_101': 'あああ',
  'gomi': 'えええ',
}

var num=Object.keys(test).map(function(v){
  return (r=v.match(/koumoku_([0-9]+)/))?parseInt(r[1]):null;
}).filter(function(v){
  return v!==null;
}).sort();

for (var i = 0; i < num.length; i++) {
  console.log(test["koumoku_"+num[i]]);
} 

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/04/12 09:51

    今回はデータの見やすさから連番指定ということになりましたが、配列だと処理しやすいというのが分かりますね。ご回答ありがとうございました!

    キャンセル

+3

今回の質問のケースの場合はobjectを列挙するかたちで問題なさそうですが、一応、ObjectとMapでは列挙のされ方に違いがあるので、両パターンを参考までに置いておきます。

 Object

const obj = {
    [Symbol('symbol')]: 'symbol',
    koumoku: 'あああ',
    koumoku_1: '111',
    koumoku_2: '222',
    koumoku_3: '333',
    '3': 'さん'
}


for ( let key in obj) {
    console.log(obj[key])
}

// 以下ログの結果

// さん
// あああ
// 111
// 222
// 333

 ポイント

  • 挿入順に列挙される保証はない
  • Symbolはfor inで列挙されない
  • 1"1"など数字っぽいkeyが'aaa'のような文字列より順序が優先される(言語仕様というより、これはモダンブラウザの実装による)

 Map

const dic = new Map([
    [Symbol(), 'symbol'],
    ['koumoku', 'あああ'],
    ['koumoku_1', '111'],
    ['koumoku_2', '222'],
    ['koumoku_3', '333'],
    ['3', 'さん']
])

// これでもOK
// console.log(...dic.values())

for (let [key, value] of dic) {
    console.log(value);
}

// 以下ログの結果

// symbol
// あああ
// 111
// 222
// 333
// さん

 ポイント

  • Symbolも列挙されるし、また、全て挿入順に列挙される

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/04/12 09:53

    ご回答ありがとうございます。
    オブジェクトに含まれるデータ(名前の統一性含め)が揃っていないようなときはご教授頂いた方法がとても役立ちそうです。勉強になりました!ありがとうございます!

    キャンセル

checkベストアンサー

+2

for (var i = 0; i < test.length; i++)
{
    console.log(test["koumoku_" + (i + 1)]); // こんなんで行けたような遥かな記憶…
}

オブジェクトのプロパティアクセス

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/04/12 09:46

    ご回答ありがとうございました。
    こちらの方法で無事連番のプロパティ値を拾うことができました。
    ありがとうございました!

    キャンセル

+1

これでいけませんでしょうか。

for (var i = 0; i < test.length; i++) {
  console.log(test["koumoku_" + (i + 1)]); 
} 

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/04/11 09:00

    スミ括弧の数が合っていないようななな

    キャンセル

  • 2018/04/11 09:01

    そうですね。修正します。luckerさんの回答と同じ結果になると思います。

    キャンセル

  • 2018/04/11 09:01

    うふふふふ。

    キャンセル

  • 2018/04/12 09:46

    ありがとうございました。
    こちらと同様のコードにて処理させることができました!

    キャンセル

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

  • ただいまの回答率 90.37%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • JavaScript

    18784questions

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

  • jQuery

    7555questions

    jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

  • Monaca

    1048questions

    「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

  • Cordova

    450questions

    Cordovaは様々なデバイスで使うことができるオープンソースなモバイル用開発プラットフォームです。開発者に各デバイスの元のプラットフォームで開発する必要をなくし、HTML・JavaScript・CSSなどの一般的なウェブのテクノロジーを使ってすべてのデバイスで展開することができるモバイルのアプリケーションを生成することを可能にします。