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

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

新規登録して質問してみよう
ただいま回答率
85.48%
JavaScript

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

Q&A

解決済

1回答

9844閲覧

return this; について

退会済みユーザー

退会済みユーザー

総合スコア0

JavaScript

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

0グッド

1クリップ

投稿2016/06/15 21:02

あるコードをみていて、
javascriptのクラスの定義時に
プロトタイプのメソッドの中に
return this;としているのは、なぜでしょうか?
また、prototype をローカル変数にするメリットは
なんでしょうか?
勉強不足で申し訳ありませんが、よろしくお願いいたします。

javascript

1var index = index || {}; 2 3(function($) { 4 index.MyClass = (function() { 5 function MyClass() { 6 this.props = { 7 prop1: prop1, 8 prop2: prop2 9 }; 10 this._init(); 11 } 12 13 // prototype をローカル変数へ 14 var p = MyClass.prototype; 15 16 p._init = function() { 17 var self = this; 18 $window.scroll(function() { 19 //省略 20 }); 21 }; 22 23 p._controller = function(y) { 24 if (this.props.prop1 < y) { 25 this.methodA(); 26 } else { 27 this.methodB(); 28 } 29 }; 30 31 p.methodA = function() { 32 33 /* 34 省略 35 */ 36 37 return this; 38 }; 39 40 p.methodB = function() { 41 42 /* 43 省略 44 */ 45 46 return this; 47 }; 48 49 // class MyClass 50 return MyClass; 51 }()); 52 53 $(function() { 54 index.myclass = new index.MyClass(); 55 56 }); 57 58}(jQuery)); 59

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

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

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

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

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

guest

回答1

0

ベストアンサー

return this

return this すると該当オブジェクトのインスタンスを返すのでメソッドチェーンが出来るようになります。

JavaScript

1new index.MyClass().methodA().methodB()

prototype をローカル変数化

index.MyClass.prototype をローカル変数にすると、毎回、index.MyClass.prototype = function () {}; するよりもプロパティ参照が速くなります。
最も、Object.defineProperties を使用すれば、index.MyClass.prototype の参照は一回で済むのですが…。

Re: takapoy さん

投稿2016/06/15 21:42

編集2016/06/15 21:51
think49

総合スコア18162

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

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

退会済みユーザー

退会済みユーザー

2016/06/16 02:46

迅速に対応していただきありがとうございました。 また、簡潔にとても分かりやすく説明していただき感謝しております。 また、他質問のほうでも私の不備のほどご指摘いただき ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問