回答編集履歴

1

追加文の説明を書き足し

2018/09/15 15:58

投稿

miyabi-sun
miyabi-sun

スコア21158

test CHANGED
@@ -69,3 +69,123 @@
69
69
  console.log(data["score"]); // 80
70
70
 
71
71
  ```
72
+
73
+
74
+
75
+ ---
76
+
77
+
78
+
79
+ > ```JavaScript
80
+
81
+ > parent[names[i]] = parent[names[i]] || {};
82
+
83
+ > parent = parent[names[i]];
84
+
85
+ > ```
86
+
87
+
88
+
89
+ for文の中身のこれですね。
90
+
91
+ for文の前に`var parent = window;`とかやってますが、parentってのは親という意味ですよね。
92
+
93
+ windowはwindowだから親でもなんでもないやん?
94
+
95
+
96
+
97
+ `parent[names[i]]`はオブジェクトのプロパティへのアクセスルールの一つでしたね。
98
+
99
+ オブジェクトに紐づくプロパティは親子関係の様にも見えます。
100
+
101
+
102
+
103
+ - parent: オブジェクトそのもの
104
+
105
+ - 子: オブジェクトのプロパティ
106
+
107
+
108
+
109
+ という擬似的な親子関係を想像して、parent変数を用意しているのです。
110
+
111
+
112
+
113
+ for文の1行目は`parent[names[i]] || {}`を`parent[names[i]]`に代入しています。
114
+
115
+ JavaScriptでは、`A || B`を評価した場合、
116
+
117
+ まずAを単体でif文に放り込んでtrueになりそうなもの(1以上の数値や文字列、オブジェクトや配列などなど…)はAそのものが返って来ます。
118
+
119
+ もしAがfalseになりそうなものだったら、Bを返します。
120
+
121
+
122
+
123
+ ```JavaScript
124
+
125
+ var data = {name: "taro", score: 80};
126
+
127
+
128
+
129
+ // data.nameは常に存在するので"taro"が返ってくる
130
+
131
+ console.log(data.name); // taro
132
+
133
+ console.log(data.name || "nanashi"); // taro
134
+
135
+
136
+
137
+ // data.ageは用意していないので18になる
138
+
139
+ console.log(data.age); // undefined
140
+
141
+ console.log(data.age || 18); // 18
142
+
143
+ ```
144
+
145
+
146
+
147
+ or演算子`||`の右辺は`{}`ですね。
148
+
149
+ 空のオブジェクトを作ってparentのプロパティに代入しています。
150
+
151
+
152
+
153
+ 続いて変数の代入の続きです。
154
+
155
+ for文の二行目の`parent = parent[names[i]]`って何をやってるんでしょうか?
156
+
157
+ えええ、`parent = window`してたよね?windowオブジェクトぶっ壊れるじゃんどうしてくれんの!?!?
158
+
159
+
160
+
161
+ そうではありません。
162
+
163
+ オブジェクトを代入した変数に、別の値を代入した場合、オブジェクトのアドレス値参照が切り離されます。
164
+
165
+ 百聞は一見に如かず、いつものdata変数でどうなるか試してみましょう。
166
+
167
+
168
+
169
+ ```JavaScript
170
+
171
+ var data = {name: "taro", score: 80};
172
+
173
+ var data2 = data;
174
+
175
+ data2.child = {name: "jiro", score: 0};
176
+
177
+
178
+
179
+ // data2はdataのアドレス値を捨てて、data.childのアドレス値に切り替わる
180
+
181
+ data2 = data2.child;
182
+
183
+ data2.score = 70;
184
+
185
+
186
+
187
+ console.log(data); // {name: "taro", score: 80, child: {name: "jiro", score: 70}}
188
+
189
+ console.log(data2); // {name: "jiro", score: 70}
190
+
191
+ ```