javascript - 《ES6標準入門》中關于修飾器的疑問
問題描述
修飾器對類的行為的改變,是代碼編譯時發生的,而不是在運行時。這意味著,修飾器能在編譯階段運行代碼。也就是說,修飾器本質就是編譯時執行的函數。
有以下幾個問題:
上面引用中說到:修飾器對類的行為的改變,是代碼編譯時發生的,而不是在運行時,這句中的編譯時、運行時、發生分別是什么意思?
修飾器本質就是編譯時執行的函數,這里的執行和問題一中的發生是一個意思嗎?
修飾器一般用在哪些地方?
書上的解釋看的比較模糊,麻煩大神細細解說,非常感謝!
問題解答
回答1:編譯時,可以大致理解為,在代碼開始運行之前,JS引擎將代碼轉化成機器可以運行的操作的時候。也就是說,這個過程無法在運行時候加以干涉的,因為它在開始運行之前就已經完成了。
而運行時,則是指你代碼編譯以后機器可以運行的操作開始運行時,也就是你寫的那些東西,從機器操作變成了你能實際在電腦上看到的東西的時候。
至于發生,并沒有特殊含義,就是指這些改變是在JS引擎將代碼轉化為機器操作過程中完成的。
執行和發生,大致可以認為是因和果的關系。改變,一般搭配的動詞是“發生”,函數,一般搭配的詞是“執行”。發生強調的是前后狀態的對比,也就是說,因為發生了某件事,導致之后和之前不同了。而執行則側重過程,執行一個操作,也就是將操作里每個步驟都做一遍,并沒有刻意去注重前后是否有不同。所以,這邊應該是修飾器=編譯時執行的函數,這個函數執行之后導致的結果是類行為有所改變。
既然,上面說了,是對類行為的改變,所以修飾器一般用在類聲明時候對類里面方法和屬性的修飾。
回答2:說白了,代碼大體分編譯階段和運行階段,你可以理解成編譯階段把代碼解析成一個樹,到了運行階段時,按照編譯形成的樹進行運行。你可以在github上搜索一下core-decorators.js,這個庫就是一個修飾器的實例。
相關文章:
1. sql語句 - 如何在mysql中批量添加用戶?2. shell - Update query wrong in MySQL3. 怎么php怎么通過數組顯示sql查詢結果呢,查詢結果有多條,如圖。4. javascript - mysql插入數據時怎樣避免與庫中的數據重復?5. php - 數據庫表如果是null怎么替換為其他字段的值6. 事務 - mysql共享鎖lock in share mode的實際使用場景7. SQLAlchemy 訪問Mysql數據庫彈出Warning,VARIABLE_VALUE,如何解決?8. mysql - JAVA怎么實現一個DAO同時實現查詢兩個實體類的結果集9. mysql - 數據庫建字段,默認值空和empty string有什么區別 11010. mysql建表報錯,查手冊看不懂,求解?
