[問題] 有辦法印出this的內容嗎?

看板Ajax作者 (todo se andarà)時間8年前 (2016/05/03 12:00), 8年前編輯推噓5(5017)
留言22則, 5人參與, 最新討論串1/2 (看更多)
小弟還是新手 想問~目前在看open source的project 在trace時一堆this實在看得很痛苦 但this印出時 只有global會印出windows的樣子... 其他都是[object Object] 不知道有沒有辦法直接印出this指向的內容是什麼呢? 都可以知道他是object了代表應該知道他實際指的內容是什麼吧!? 還是沒辦法? 如果沒辦法的話又是為什麼呢? 謝謝各位~ -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.116.247.244 ※ 文章網址: https://www.ptt.cc/bbs/Ajax/M.1462248031.A.76D.html

05/03 13:06, , 1F
console.log(this) 或 console.dir(this)
05/03 13:06, 1F

05/03 13:06, , 2F
開瀏覽器的開發人員主控臺直接下中斷點看最快
05/03 13:06, 2F
因為不是網頁 好吧我直接說好了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

05/03 16:44, , 3F
node.js嗎? util.inspect(x); 試試看!
05/03 16:44, 3F

05/03 16:45, , 4F
更正 util.inspect(this);
05/03 16:45, 4F
不是唷是純JS 還是感謝你的建議~

05/04 15:26, , 5F
印出x{...}應該是不太可能的 所屬變數只可能當下查
05/04 15:26, 5F

05/04 15:27, , 6F
不過如果是chrome 你new A()產生出來的object在log裡
05/04 15:27, 6F

05/04 15:27, , 7F
會呈現A {...} 的型態
05/04 15:27, 7F

05/04 15:27, , 8F
無論A是function還是ES2015的class都有效
05/04 15:27, 8F

05/04 15:28, , 9F
原則上 同一個物件可能同時被一堆變數指向 目前沒方
05/04 15:28, 9F

05/04 15:28, , 10F
法讓你根據記憶體位置去查詢有哪些變數指向它
05/04 15:28, 10F
好吧 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

05/05 10:17, , 11F
temp這個變數在new時還沒有產生阿
05/05 10:17, 11F

05/05 10:18, , 12F
this就會指到目前自己這個object,只是temp是undefined
05/05 10:18, 12F

05/06 20:46, , 13F
this在不同的場合會指向不同的目標,通常是自己,如果是一
05/06 20:46, 13F

05/06 20:46, , 14F
個被呼叫的function的話,就是指向呼叫這個函數的物件,比
05/06 20:46, 14F

05/06 20:46, , 15F
如一個callback會指向綁listener的那個物件,如果有call或
05/06 20:46, 15F

05/06 20:46, , 16F
apply什麼的,就是看你綁誰。我記得MDN有很仔細的解釋可以
05/06 20:46, 16F

05/06 20:46, , 17F
看一下
05/06 20:46, 17F

05/06 22:21, , 18F
mars90226的回答是正解 這邊原po對this的理解無誤
05/06 22:21, 18F

05/06 22:26, , 19F
new的時候this是指向一個剛生出來的空物件
05/06 22:26, 19F

05/06 22:26, , 20F
之所以不等於temp 是因為該空物件尚未被派給temp
05/06 22:26, 20F

05/08 14:15, , 21F
謝囉各位
05/08 14:15, 21F

05/08 14:19, , 22F
總覺得好不直觀XD
05/08 14:19, 22F
想在問各位 在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
文章代碼(AID): #1NA29VTj (Ajax)
文章代碼(AID): #1NA29VTj (Ajax)