- ベストアンサー
if (typeof hoge == 'funct
Picosoftの回答
・hogeという変数が既に宣言されていること(宣言されていない場合はundefinedになる) ・hogeが関数オブジェクトであること(関数でなければ"hoge()"という書き方はできない) をチェックしたいんじゃないですか? なくてもいいかどうかはコード全体を見ないと何とも言えません。
関連するQ&A
- (hoge)("fuge"); はどういう意味を持つのでしょうか?
匿名関数を理解するために、下記ブログを参考にしました。 匿名関数と (function(){ ... })(); について : JavaScript 備忘録 http://blog.livedoor.jp/jsmemo/archives/767707.html 簡潔なコードで完全ではありませんが、理解できました。 ただ、下記コードだけは理解できませんでした。 ------- var hoge = function(str){ alert(str); }; (hoge)("fuge"); ------- ("fuge") でfunctionに引数を渡しているようですが、(hoge) の意味がわかりません。 同じような情報で下記ブログを読むと、 匿名関数の定義と実行 - 昼間のメモ http://blog.goo.ne.jp/hiuchida/e/431b5beb4adeb313a49b35c055f02df3 「C言語の関数へのポインタを使った関数呼出しを知っていれば同じだと分かるでしょう。」とありますが、 C言語に触ったことのない私には見当が付きませんでした。 「JavaScript ポインタ」でGoogle検索すると、マウスポインタに関する情報ばかりがHITしてしまいます。 何かヒントとなる情報はありませんでしょうか?
- ベストアンサー
- JavaScript
- javascriptのconstructorプロパティについて
constructorプロパティとは、 オブジェクトの初期化で使用されたコンストラクタ関数を参照 とのことなので、下記2パターンのPGを作成しました 1.prototypeの明記なし function Hoge(){ this.init = "Hogeで初期化"; this.getInit = function(){ return this.init; } } var obj = new Hoge(); alert(obj.constructor == Hoge); for(prop in obj){ alert( prop + " - " + obj[prop]); } //実行結果 True init - Hogeで初期化 getInit - function () { return this.init; } 2.prototypeの明記あり function Hoge(){ this.initialize.apply(this,arguments); this.init = "Hogeで初期化"; this.getInit = function(){ return this.init; } } Hoge.prototype ={ initialize:function(){ this.init = "Hoge.prototype.initializeで初期化"; }, getInit:function(){ return "Hoge.prototype.getInit()"; } } var obj = new Hoge(); alert(obj.constructor == Hoge); for(prop in obj){ alert( prop + " - " + obj[prop]); } //実行結果 false init - Hogeで初期化 getInit - function () { return this.init; } initialize - function () { this.init = "Hoge.prototype.initialize\u3067\u521D\u671F\u5316"; } ・質問内容 prototypeの明記なしの場合は、Hogeのコンストラ関数を参照している(結果がTrueのため) prototypeの明記ありの場合は、falseのためコンストラ関数を参照していないのですが、 prototype明記あり、なしで結果が異なる理由が分からない状態です。 (prototype.constructorにも手を出したのですが、上記が解決しないため constructorプロパティに関してのみ質問した次第です) ネット、書籍等で調べたのですが、検討がつかない状態です。 お手数ですが、ご教授お願い致します。
- ベストアンサー
- JavaScript
- 本文ではなく、returnへほとんどの処理を記述
・本文ではなく、returnへほとんどの処理を記述しているコードがあります ・どういう意図があるのでしょうか? ・複数の関数をreturnする関数が、たくさんあります ・どの関数も、関数本文より、returnする関数内容の方が何倍も多いです hoge = function(){ //中略 return { a : function(){ }, b : function(){ //これが延々続く //return関数内で即時関数実行したり ■質問1 ・処理の結果をreturnすると思っていたのですが、returnメインでそこに処理を記述していくやり方のメリットは? ■質問2 ・hoge.aでアクセスしているのですが、関数定義=オブジェクト定義でしょうか? ・下記aメソッドは、同じ意味? hoge = { a: function(){ hoge = function(){ //中略 return { a : function(){ },
- 締切済み
- JavaScript
- setTimeoutのthis参照について
prototypeメソッドの中でsetTimeout関数を使用したところ、thisで自身の関数を参照しなくなりました。setTimeoutの挙動についてぐぐってみたのですが、いまいちsetTimeoutを使用したときのスムーズな記述方法がわかりません。 ******************************** var hoge=function(){ this.myName="ほげ"; } hoge.prototype={ init:function(){ setTimeout(function(){ hoge.prototype.displayName(); // ★(1)setTimeout関数の中でのメソッドの適した呼び出し方は? // ↑の記述でも呼び出せるけど、間違ってる気がする。。 },1000) }, displayName:function(){ // ★(2)ここでhogeオブジェクトのmyNameプロパティを参照するにはどう記述すれば良いのか? //console.log(this.myName); //↑setTimeoutを使ったのでthis参照はwindowオブジェクトになっているから違う //console.log(hoge.myName); →undefinedを返す } } window.onload=function(){ var a=new hoge(); a.init(); } ******************************** 上記のようなprototype関数を使用したときのスムーズな記述方法を教えていただけませんでしょうか。 知りたいのは下記2点です。 ★(1)prototypeメソッドを使用したとき、setTimeout関数の中でのメソッドの適した呼び出し方は? ★(2)setTimeout関数内で呼び出したメソッドから、自身のオブジェクトのプロパティを参照するにはどう記述すれば良いのか? 初心者なので説明が下手だったり、質問内容で間違った記述があるかもしれません。 質問内容で問題がありましたらご指摘いただけると助かります。
- ベストアンサー
- JavaScript
- 関数を呼び出すHTMLタグ<body onload="hoge()">について
ほぼ独学でJavaScriptを学んでいるので、一般的なコード(HTML含め)の書き方が分かりません。 JavaScriptでは、ボタンや画像をクリックすると動作する、 というものが多いですが、そうではなくて、 (それはonclick等で関数を呼び出せば良いことは分かります) 時計のように、アクセスした瞬間から実行されるプログラムを複数書きたい時は、 どのようにするのが妥当でしょうか。 <body onload="hoge()">では、関数hoge()しか実行されないことになりますよね。 そうではなくて、hoge()以外にもいくつかの関数を実行したい時はどうするのが一般的ですか? ここでC言語のように、hoge()をmain関数(int main(void){})のような扱い方にすると、 hoge()関数内で呼び出されている関数も呼び出されることになりますが、そのような書き方で良いですか? アクセスの効率の良さから考えて、他に良いやり方はあるでしょうか。 ・・・前に困ったので<body>タグを2つ付けて2つの関数をonloadアトリビュートで呼び出すという、 奇々怪々なことをやってみて、それでIE7,FireFox3で動いていたので驚いたんですが、 そんなやり方はさすがに御法度ですよね(笑)。 答えにくい質問だと思いますが、アドバイスお願いします。
- ベストアンサー
- JavaScript
- 例外ってIf文の中に入れますか?If文の外でTry...Catchしますか??
例外ってIf文の中に入れますか?If文の外でTry...Catchしますか?? Sub Cal(By Val Data As String) If ( Flag = "hoge") Then Total = js.Eval(Work) End If End Sub それと、”エラーコードをテキストの説明に変換する”FormatMessage関数を使おうと思っています。 「例外処理 = FormatMessage関数」という図式は古いですか?いまはもっと違う方法ですか?
- ベストアンサー
- Visual Basic
- PERLの「!=」と「=~」 or 「if」と「unless」必ずしも真反対の意味ではない?
下記コードは、同じ意味だと思っていたのですが、 実行すると違った結果が表示されます。 何故でしょうか? my $string = 'A-test'; unless($string =~ m/-Hoge/){print '=~>',$string;} if($string != m/-Hoge/){print '!=>',$string;}
- ベストアンサー
- Perl
- オブジェクトの中で呼び出される順番とデフォ引数?
・意味が分からないコードがあるので教えてください ■コード var arg; var obj = { hoge : function( arg ) { var hoge = function(arg){ return function() { } }(arg); hoge(); } } ■質問 ・この時、obj.hoge(arg);と書いたら、どういう処理が走るのでしょうか? ・初めに実行されるのは? 無名関数部分? それともhoge()? ・hoge()を実行する際、引数指定していないので、引数は渡らない?
- ベストアンサー
- JavaScript
- execl2010 if関数について
いつもお世話になっています。 EXECL2010でIF関数を設定しようとしています。 漢字かブランクでデータを入力させたいと考えています。 =IF(AND(CODE(I11)>=12322,CODE(I11)<=29734),(I11)""),"","1:00") 片方ずつは動きますが、ブランクを条件に足すとエラーとなります。 どこがダメなのかご教授頂けたら幸いです。 どうぞよろしくお願いします。
- ベストアンサー
- その他([技術者向] コンピューター)
お礼
回答ありがとうございましたー