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

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

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

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

Q&A

解決済

2回答

2480閲覧

JavaScript入門者 プロパティを用意しても未定義となる理由が知りたい。

退会済みユーザー

退会済みユーザー

総合スコア0

JavaScript

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

0グッド

0クリップ

投稿2021/09/18 15:41

提示コードのコメント部//////////内部コードですがプロパティを用意してもなぜ未定義と表示されるのでしょうか?参考サイトの通りにやってもエラーが出ます。

参考サイト: https://www.tohoho-web.com/js/class.htm

Error

1Uncaught TypeError: Cannot read properties of undefined (reading 'getPosition') 2 at Game.js:134 3 at Array.forEach (<anonymous>) 4 at Game.Update (Game.js:131) 5 at Entry.Loop (Entry.js:13) 6 at draw (Main.js:19) 7 at p5._main.default.redraw (p5.js:70809) 8 at _draw (p5.js:63046)

javascript

1 2class Enemy 3{ 4 constructor(pos) 5 { 6 this.position = new Vector(pos.x,pos.y); 7 this.alive = true; 8 this.size = 50; 9 } 10 11 Init(pos) 12 { 13 this.position = new Vector(pos.x,pos.y); 14 this.alive = true; 15 16 } 17 18 Update() 19 { 20 21 } 22 23 Renderer() 24 { 25 //fill(color(0,100,0)); 26 line(this.position.x,this.position.y,this.position.x + this.size,this.position.y + this.size); 27// triangle(this.position.x,this.position.y + this.size, 28 // this.position.x - this.size,this.position.y - this.size, 29 // this.position.x + this.size,this.position.y - this.size); 30 31 } 32 33} 34 35 36class Player 37{ 38 constructor() 39 { 40 this.acce = new Vector(0,0); //sin波 41 this.position = new Vector(300,300); 42 this.acce = new Vector(0,0); 43 this.alive = true; 44 this.size = 100; 45 } 46 47 get getPosition() 48 { 49 return this.position; 50 } 51 52 set setPosition(p) 53 { 54 this.position.x = p.x; 55 this.position.y = p.y; 56 57 } 58 59 60 Update() 61 { 62 KeyInput(this.position,this.acce); 63 } 64 65 66 Renderer() 67 { 68 line(this.position.x,this.position.y,this.position.x + this.size,this.position.y + this.size); 69 70 } 71 72} 73 74class Bullet 75{ 76 77} 78 79 80class Game 81{ 82 83 //オブジェクトプール 84 EnemyInstance(pos) 85 { 86 this.enemy.forEach(item => 87 { 88 89 if(item.alive === false) 90 { 91 item.Init(pos); 92 return; 93 } 94 95 96 }); 97 98 this.enemy.push(new Enemy(new Vector(pos.x,pos.y))); 99 return; 100 } 101 102 constructor() 103 { 104 105 this.enemy = new Array(); //Enemy 配列 106 this.Player = new Player(); //Player 107 108 for(let i = 0; i< 10; i++) 109 { 110 this.EnemyInstance(new Vector(100 + 40 * i,100)); 111 } 112 113 114 } 115 116 117 Collision(posA,posB) 118 { 119 if(Collision.LineSegment(posA,posB) == true) 120 { 121 return true; 122 } 123 else 124 { 125 return false; 126 } 127 } 128 129 Update() 130 { 131 this.enemy.forEach(item => 132 { 133 item.Update(); 134//////////////////////////////////////////////////////////////////////////////////////////////////////////// 135 if((this.Collision(this.player.getPosition,item.position) === true) && (item.alive === true)) 136 { 137 item.alive = false; 138 } 139//////////////////////////////////////////////////////////////////////////////////////////////////////////// 140 }); 141 142 143 144 145 } 146 147 148 Renderer() 149 { 150 this.enemy.forEach( item => item.Renderer()); 151 this.plyer.Renderer(); 152 } 153 154 155 156 157 158 159}

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

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

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

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

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

guest

回答2

0

プロパティが未定義なのではありません。

undefinedのオブジェクトにgetPositionというプロパティがないとエラーメッセージに書かれているのです。

投稿2021/09/18 15:56

ishina_yum

総合スコア509

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

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

退会済みユーザー

退会済みユーザー

2021/09/18 23:43

なるほど質問ですがJacaScirptの場合はget set を定義するかしか参照する方法はないのでしょうか?
guest

0

ベストアンサー

大文字・小文字をタイプミスしていませんか?

javascript

1誤)this.Player = new Player(); //Player 2正)this.player = new Player(); //Player

投稿2021/09/18 16:30

cx20

総合スコア4633

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問