昨天看了一些關於大量 DOM 的事情,今天來聊一下關於深度監看的事情。其實在 Vue 裡面,預設的監看並不會看太多,也就是不會看很深。為了效能考量,所以基本上各家前端框架在這件事情上面,或多或少都會留一點餘地。 然後這些餘地有時候會讓人覺得很困擾。 怎麼監看? 實際上 JavaScript 是可以透過 Proxy, Reflect 來實作一個簡易的監看方法。 const onChange = (objToWatch, callback) => { const handler = { get(target, property, receiver) { callback(); const