作者aa06697 (todo se andarà)
看板Ajax
標題[問題] 有辦法印出this的內容嗎?
時間Tue May 3 12:00:24 2016
小弟還是新手 想問~目前在看open source的project
在trace時一堆this實在看得很痛苦
但this印出時 只有global會印出windows的樣子...
其他都是[object Object]
不知道有沒有辦法直接印出this指向的內容是什麼呢?
都可以知道他是object了代表應該知道他實際指的內容是什麼吧!?
還是沒辦法? 如果沒辦法的話又是為什麼呢?
謝謝各位~
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.116.247.244
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Ajax/M.1462248031.A.76D.html
1F:→ mrbigmouth: console.log(this) 或 console.dir(this) 05/03 13:06
2F:→ mrbigmouth: 開瀏覽器的開發人員主控臺直接下中斷點看最快 05/03 13:06
因為不是網頁 好吧我直接說好了XD 在看的是selenium 因為他是XUL不算是網頁(?)
所以應該沒辦法用大大說的方法看(雖然我也不知道下中斷點的意思= =)
而且我自己測了一下 用firefox的firebug
function A() {
console.log(this);
}
var x = {...};
A.call(x);
這樣還是只有印出object {...} 而沒辦法印出 x{...}
還是要印出這樣是不可能的?
※ 編輯: aa06697 (140.116.1.136), 05/03/2016 15:17:38
3F:推 tooto1985: node.js嗎? util.inspect(x); 試試看! 05/03 16:44
4F:→ tooto1985: 更正 util.inspect(this); 05/03 16:45
不是唷是純JS 還是感謝你的建議~
5F:→ mrbigmouth: 印出x{...}應該是不太可能的 所屬變數只可能當下查 05/04 15:26
6F:→ mrbigmouth: 不過如果是chrome 你new A()產生出來的object在log裡 05/04 15:27
7F:→ mrbigmouth: 會呈現A {...} 的型態 05/04 15:27
8F:→ mrbigmouth: 無論A是function還是ES2015的class都有效 05/04 15:27
9F:→ mrbigmouth: 原則上 同一個物件可能同時被一堆變數指向 目前沒方 05/04 15:28
10F:→ mrbigmouth: 法讓你根據記憶體位置去查詢有哪些變數指向它 05/04 15:28
好吧 Orz... 另外想問大大一個問題
function A() {
console.log(this == temp);
}
var temp = new A();
這樣為什麼會印出false呢? 不是new的時候this會指向temp嗎?
我自己是這樣想:
一開始是創建「空物件」然後this指向此 進去執行A之後
執行完後才會是 var temp = new A()的 "="
所以此時temp才會指向空物件
是這樣嗎?如果是的話 那一開始在A裡面的this就是指向一個未定的object這樣?
※ 編輯: aa06697 (111.255.235.21), 05/05/2016 00:02:07
※ 編輯: aa06697 (111.255.235.21), 05/05/2016 00:06:12
11F:推 mars90226: temp這個變數在new時還沒有產生阿 05/05 10:17
12F:→ mars90226: this就會指到目前自己這個object,只是temp是undefined 05/05 10:18
13F:推 p52189: this在不同的場合會指向不同的目標,通常是自己,如果是一 05/06 20:46
14F:→ p52189: 個被呼叫的function的話,就是指向呼叫這個函數的物件,比 05/06 20:46
15F:→ p52189: 如一個callback會指向綁listener的那個物件,如果有call或 05/06 20:46
16F:→ p52189: apply什麼的,就是看你綁誰。我記得MDN有很仔細的解釋可以 05/06 20:46
17F:→ p52189: 看一下 05/06 20:46
18F:推 mrbigmouth: mars90226的回答是正解 這邊原po對this的理解無誤 05/06 22:21
19F:推 mrbigmouth: new的時候this是指向一個剛生出來的空物件 05/06 22:26
20F:→ mrbigmouth: 之所以不等於temp 是因為該空物件尚未被派給temp 05/06 22:26
21F:→ aa06697: 謝囉各位 05/08 14:15
22F:→ aa06697: 總覺得好不直觀XD 05/08 14:19
想在問各位 在xul內 <window onload="new Temp()">
接著
function Temp() {
myFunc.call(this);
}
這樣在myFunc裡面的this...就會是一個空物件@@?
※ 編輯: aa06697 (111.255.236.81), 05/08/2016 16:21:52
還有...關於所謂的「空物件」 到底是指什麼呀?
http://stackoverflow.com/questions/1646698/what-is-the-new-keyword-in-javascript
他中間有給一段example 在obj1 = new ObjMaker();
他是說A new, empty object was created called obj1
所以一開始創建出來的那個空物件 其實是 obj1 = {} ?
那直接new ObjMaker() 出來的空物件 又是什麼囧
※ 編輯: aa06697 (111.255.236.81), 05/08/2016 16:39:35