摘要:從正則表達式可知不管書寫是還是在之后為注意在的已經開始返回原始內容包含空格輸出輸出可選是因為對象簡寫語法獲取類型在后不可靠提供了修改返回的類型標簽獲取原型通過構造一個通過獲得原型參考文檔文章若有紕漏請大家補充指正謝謝殤
Function.prototype.toString
從正則表達式 /^s*(?:function)?*/
可知
1: GeneratorFunction 不管書寫是 function* 還是 function * 在 Function.prototype.toString 之后為 function*
注意
在 ES2019 的 Function.prototype.toString revision 已經開始返回原始內容, 包含空格
function * fn() {}
Function.prototype.toString.call(fn);
node < 10, 輸出 function* fn() {}
node >=10, 輸出 function * fn() {}
2: function 可選是因為對象簡寫語法
var o = { *fn() {}, }; // *fn() {} console.info(Function.prototype.toString.call(o.fn));Object.prototype.toString 獲取類型在 ES2015 后不可靠
var hasToStringTag = typeof Symbol === "function" && typeof Symbol.toStringTag === "symbol"; if (!hasToStringTag) { var str = toStr.call(fn); return str === "[object GeneratorFunction]"; }
ES2015 提供了 [Symbol.toStringTag] 修改 Object.prototype.toString() 返回的類型標簽
function* fn() {} Object.defineProperty(fn, Symbol.toStringTag, { get() { return "MyTag"; }, }); // [object MyTag] console.log(Object.prototype.toString.call(fn));獲取 GeneratorFunction 原型
通過 Function 構造一個 GeneratorFunction, 通過 Object.getPrototypeOf 獲得原型
var getProto = Object.getPrototypeOf; var generatorFunc = Function("return function*() {}")(); var GeneratorFunction = getProto(generatorFunc);參考文檔
is-generator-function
Function-prototype-toString-revision
文章若有紕漏請大家補充指正,謝謝~~
http://blog.xinshangshangxin.com SHANG 殤
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/102621.html
摘要:從一個對象里面提取需要的屬性這篇文章一直想寫了還想起那一夜我看到白天的代碼,實在太美了。 koa源碼lib主要文件有 application.js context.js request.js response.js application.js koa主要的邏輯處理代碼整個koa的處理 context.js 將req,res方法 掛載在這,生成ctx上下文對象 requests....
摘要:最近讀了的源碼,理清楚了架構設計與用到的第三方庫。本系列將分為篇,分別介紹的架構設計和個核心庫,最終會手動實現一個簡易的。本文來自心譚博客深入源碼核心庫原理所有系列文章都放在了。這一段邏輯封裝在了核心庫里面。 最近讀了 koa2 的源碼,理清楚了架構設計與用到的第三方庫。本系列將分為 3 篇,分別介紹 koa 的架構設計和 3 個核心庫,最終會手動實現一個簡易的 koa。這是系列第 2...
摘要:老伙計今天我們來講一下的還有一些自己寫的庫吧。我們常用來在中間件發出一些錯誤狀態碼。從而使得上級中間件可以這個錯誤從而響應默認的一個錯誤處理如果不是實例。看完全文都是好樣的源碼鏈接文檔鏈接 hey 老伙計 今天我們來講一下koa的context.js還有一些tj自己寫的庫吧。 context.js use strict; const createError = require(htt...
摘要:一些方法不應該這樣不應該漫無目的地隨手拿起一分源碼,試圖去通讀。應該這樣精心挑選要閱讀的源碼項目。這最好是與你的編程語言你的工作內容你的興趣所在相關的,這樣才能更切實地感受到閱讀源碼給你帶來的益處,更有動力繼續。 showImg(https://segmentfault.com/img/bVbcvmm?w=785&h=525); 怎么閱讀源碼 沒有經驗的技術差底子薄的初級程序員,如何閱...
閱讀 837·2021-11-18 10:07
閱讀 2355·2021-10-14 09:42
閱讀 5315·2021-09-22 15:45
閱讀 585·2021-09-03 10:29
閱讀 3462·2021-08-31 14:28
閱讀 1873·2019-08-30 15:56
閱讀 3038·2019-08-30 15:54
閱讀 994·2019-08-29 11:32