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

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

ただいまの
回答率

89.21%

JavaScriptにおけるコロン

解決済

回答 2

投稿

  • 評価
  • クリップ 2
  • VIEW 11K+

パソコン初心者のため、暖かい目で見ていただけると幸いです。

JavaScriptのスクリプトで、よく分からない記述がありました。

sample: new Array(),

samplefunc1: function(fn) {
     this.sample.push(fn);
},

get_samples: function() {
     try {
         this.lock = true;
         execute_samples()
     } catch(e) {
         this.lock = false;
         return;
      }
     this.lock = false;
}
...

この、XXX: XXXX...という書き方はどういった意味なのでしょうか?
調べてみたのですが、ラベルでもなさそうですし、一体どういう意味なのかわかりませんでした。

どなたかご教授いただけないでしょうか?

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

+5

オブジェクト初期化子( Object initializer )を使ってオブジェクトを作る記法です。オブジェクトの生成とプロパティ/メソッドの定義などをおこなっています。

var object = {
      a: 'bar'
    , b: 42
    , c: { f: 12 }
    , d: function ( x ) { return x + 8; }
}
console.log( object.a ); // 'bar'
console.log( object[ 'b' ] ); // 42
console.log( object.c.f ); // 12
console.log( object.d( 42 ) ); // 50

【Object initializer - JavaScript | MDN】
https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Operators/Object_initializer

【オブジェクトを利用する - JavaScript | MDN】
https://developer.mozilla.org/ja/docs/Web/JavaScript/Guide/Working_with_Objects

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/05/24 23:51

    ご回答、ありがとうございます。

    自分の知識不足なところだとは思いますが、1点疑問があります。
    通常、オブジェクトを初期化する際に
    var object = {
    prop1: 'value1',
    prop2: 'value2',
    ...
    }
    などという形で記述するかと思うのですが、質問にあるコードだと、「var object = {」と「}」が抜けているようにしか見えません。
    これでもJavaScriptは正しく動作するのでしょうか?
    時折、とんでもないコードで動作するのを見て、うひゃぁとなってしまいますが・・・

    キャンセル

  • 2016/05/25 00:47

    think49さんの回答の通り、おそらく書かれているコードは何らかのコードの一部分なので、ここだけ切り取っても動きません。

    > 「var object = {」と「}」が抜けているようにしか見えません。
    たとえば、関数の引数にオブジェクトを渡している場合は var object = {}; という形をとらなくてもかけます。
    var somefunction= function( a ) { console.log( a ); };
    somefunction( {
    a: 'bar'
    , b: 42
    , c: { f: 12 }
    , d: function ( x ) { return x + 8; }
    } );
    は下記とほぼ同じはず。
    var somefunction= function( a ) { console.log( a ); };
    var object = {
    a: 'bar'
    , b: 42
    , c: { f: 12 }
    , d: function ( x ) { return x + 8; }
    };
    somefunction( object );

    キャンセル

checkベストアンサー

+3

質問文のコードをそのまま実行すると SyntaxError になります。

sample: new Array(),

samplefunc1: function(fn) { // SyntaxError: Unexpected token :
     this.sample.push(fn);
},

this.sample.push(fn) の書き方から判断するに、前後にオブジェクト初期化子特有の記述があるものと想像できます。
そうでなければ、this.sample はグローバル変数 sample が存在しなければなりませんし、カンマのつけ方も不自然です。
この記法は label 文にも見られますが、label 文としても間違っています。

確かなことはコード全体を読まないと判断できませんので、更なる検証を求める場合はすべてのコードを開示してください。
また、そのJavaScriptコードを実行する実行環境も教えてください。
それがブラウザではない場合、その実装特有の文法が存在する可能性があります。

Re: Divided_by_Zero さん

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/06/01 16:20

    やはり、実行できませんよね…
    とある参考書に書いてあった内容なのですが、その時点で全体から抜粋されていたので、私も全体のコードはわかりません(申し訳ないです…)
    もしかしたら、擬似コードのようなものなのかもしれません
    お騒がせしてしまい申し訳ないです
    kei344さん、think49さんご回答いただき、ありがとうございました!

    キャンセル

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

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