① js 什麼是函數式編程
寫一個函數(即方法:function),然後去調用這個方法、比如寫個C的helloworld然後調用printf就是函數式(過程化)編程,
補充:JavaScript一種直譯式腳本語言,是一種動態類型、弱類型、基於原型的語言,內置支持類型。它的解釋器被稱為JavaScript引擎,為瀏覽器的一部分,廣泛用於客戶端的腳本語言,最早是在HTML(標准通用標記語言下的一個應用)網頁上使用,用來給HTML網頁增加動態功能。
在1995年時,由Netscape公司的Brendan Eich,在網景導航者瀏覽器上首次設計實現而成。因為Netscape與Sun合作,Netscape管理層希望它外觀看起來像Java,因此取名為JavaScript。但實際上它的語法風格與Self及Scheme較為接近。
② 《函數式編程思維》pdf下載在線閱讀,求百度網盤雲資源
《函數式編程思維_-_Neal_Ford.epub》網路網盤免費下載:
鏈接: https://pan..com/s/1p8L4fcpx5odA8Is2nrf6Jg
③ 《學習JavaScript數據結構與演算法(第2版)》pdf下載在線閱讀全文,求百度網盤雲資源
《學習JavaScript數據結構與演算法(第2版)》([巴西] Loiane Groner)電子書網盤下載免費在線閱讀
鏈接:
書名:學習JavaScript數據結構與演算法(第2版)
作者:[巴西] Loiane Groner
譯者:鄧鋼
豆瓣評分:7.3
出版社:人民郵電出版社
出版年份:2017-9
頁數:232
內容簡介:
本書首先介紹了JavaScript 語言的基礎知識以及ES6 和ES7 中引入的新功能,接下來討論了數組、棧、隊列、鏈表、集合、字典、散列表、樹、圖等數據結構,之後探討了各種排序和搜索演算法,包括冒泡排序、選擇排序、插入排序、歸並排序、快速排序、堆排序、計數排序、桶排序、基數排序、順序搜索、二分搜索,然後介紹了動態規劃和貪心演算法等常用的高級演算法以及函數式編程,最後還介紹了如何計算演算法的復雜度。
作者簡介:
Loiane Groner
花旗銀行軟體開發經理,負責海外項目的開發和團隊管理;原IBM公司系統分析師及團隊負責人;巴西坎皮納斯Java用戶組(CampinasJUG)領導者、聖埃斯皮里圖Java用戶組(ESJUG)協調人;巴西各大型技術會議特邀發言人;Sencha和Java技術佈道者,通過博客(http://loianegroner.com)為軟體開發社區撰稿,發表關於IT職業發展和常用開發技術的文章和視頻。另著有《精通Ext JS》等書。
④ 《JavaScript設計模式與開發實踐》pdf下載在線閱讀全文,求百度網盤雲資源
《JavaScript設計模式與開發實踐》網路網盤pdf最新全集下載:
鏈接:https://pan..com/s/1UMDDphTVYWb5jhVl82IU5w
⑤ 《JavaScript函數式編程》epub下載在線閱讀全文,求百度網盤雲資源
《JavaScript函數式編程》([美]Michael Fogus)電子書網盤下載免費在線閱讀
鏈接:https://pan..com/s/1oxGfq6jXzct5Me-6i_oKfA
書名:JavaScript函數式編程
豆瓣評分:6.6
作者:[美]Michael Fogus
出版社:人民郵電出版社
原作名:Functional JavaScript
譯者:歐陽繼超/王妮
出版年:2015-8
頁數:204
內容簡介
JavaScript 是近年來非常受矚目的一門編程語言,它既支持面向對象編程,也支持函數式編程。本書專門介紹JavaScript函數式編程的特性。
全書共9章,分別介紹了JavaScript函數式編程、一等函數與Applicative編程、變數的作用域和閉包、高階函數、由函數構建函數、遞歸、純度和不變性以及更改政策、基於流的編程、類編程。除此之外,附錄中還介紹了更多函數式JavaScript。
本書內容全面,示例豐富,適合想要了解函數式編程的JavaScript程序員和學習JavaScript的函數式程序員閱讀。
作者簡介
Michael Fogus是Dynamic Animation Systems的軟體架構師,在分布式模擬、機器視覺和專家系統建設方面經驗豐富。他是Clojure、ClojureScript以及Underscore-contrib的貢獻者,還是《Clojure編程樂趣》的作者。
⑥ 《JavaScript語言精髓與編程實踐第三版周愛民》pdf下載在線閱讀全文,求百度網盤雲資源
《JavaScript語言精髓與編程實踐第三版周愛民》網路網盤pdf最新全集下載:
鏈接:https://pan..com/s/1S1JmDFZqAZwKSEcTx994Kw
⑦ 前端必學-函數式編程(六)
我們前篇談了很多關於【閉包】的理解了,所以你應該會知道,我們現在將要談的就是 ——【非同步】。
我們為什麼覺得「非同步問題」復雜呢?
其中很重要的一個原因是 —— 時間!時間將我們對數據的操判運作、管理,變復雜了好幾個量級!
(需要特別提出並明確的是: 非同步和同步之間是可以相互轉化的! 我們使用非同步或者同步取決於 —— 如何使代碼更加可讀!)
函數式編程給出了實現「代碼更可讀」的落地原則(已多次回顧):
所以我們可以期待,非同步在函數式編程中的表現!
上代碼:
onCustomer(..) 和 onOrders(..) 是兩個【回調函數】釋義,兩者執行的先後順序並不能確定,所以它是一個基於時間掘喚梁的復雜狀態。
釋義:回調函數其實就是一個參數,將這個函數作為參數傳到另一個函數裡面,當那個函數執行完之後,再執行傳進去的這個函數。
通常來說,我們最先想到的是:把 lookupOrders(..) 寫到 onCustomer(..) 裡面,那我們就可以確認 onOrders(..) 會在 onCustomer(..) 之後運行。
這樣寫,對嗎?
不對!因為 onCustomer(..) 、 onOrders(..) 這兩個回調函數的關系更像是一種競爭關系(都是賦值 customer.orders ), 它們應該並行執行 , 而不是串列執行 。
即:我不管你們誰先執行,誰先執行完,誰就賦值給 customer.orders !
那我們的思路應該是:
不過,這樣讓代碼又變得更加難閱讀!!函數內部賦值依賴於外部變數、甚至受外部回調函數的影響。
那究竟怎麼辦呢?
最終,我們借用 JS promise 減少這個時間狀態,將非同步轉成同步:
兩個 .then(..) 運行之前, lookupCustomer(..) 和 lookupOrders(..) 已被同步調用,滿足並行執行,誰先結束,誰賦值給 customer.orders ,所以我們不需要知道誰先誰後!
在這樣的實現下,不再需要時間先後的概念!減少了時間狀態!!代碼的可讀性更高了!!
這是一個 積極的數組 ,因為它們同步(即時)地操作著離散的即時值或值的列表/結構上的值。
什麼意思?
a 映射到 b,再去修改 a ,b 不會收到影響。
而這,是一個 惰性的數組 , mapLazy(..) 本質上 「監聽」 了數組 a,只要一個新的值添加到數組的末端(push(..)),它都會運行映射函數 v => v * 2 並把改變後的值添加到數組 b 里。
什麼意思?
a 映射到 b,再去修改 a ,b 也會修改。
原來,後者存在 非同步 的概念。
讓我們來想像這樣一個鏈櫻數組,它不只是簡單地獲得值,它還是一個懶惰地接受和響應(也就是「反應」)值的數組,比如:
設置「懶惰的數組」 a 的過程是非同步的!
b ,是 map 映射後的數組,但更重要的是,b 是 反應性 的,我們對 b 加了一個類似監聽器的東西。
這里直接給出解答:
這里再多小結一句:時間讓非同步更加復雜,函數式編程在非同步下的運用就是減少或直接幹掉時間狀態。
想像下 a 還可以被綁定上一些其他的事件上,比如說用戶的滑鼠點擊事件和鍵盤按鍵事件,服務端來的 websocket 消息等。
上述的 LazyArray 又可叫做 observable !(當然,它不止用在 map 方法中)
現在已經有各種各樣的 Observables 的庫類,最出名的是 RxJS 和 Most 。
以 RxJS 為例:
不僅如此,RxJS 還定義了超過 100 個可以在有新值添加時才觸發的方法。就像數組一樣。每個 Observable 的方法都會返回一個新的 Observable,意味著他們是鏈式的。如果一個方法被調用,則它的返回值應該由輸入的 Observable 去返回,然後觸發到輸出的 Observable里,否則拋棄。
比如:
本篇介紹了【非同步】在函數式編程中的表現。
原則是:對於那些非同步中有時態的操作,基礎的函數式編程原理就是將它們變為無時態的應用。即 減少時間狀態 !
就像 promise 創建了一個單一的未來值,我們可以創建一個積極的列表的值來代替像惰性的observable(事件)流的值。
我們介紹了 RxJS 庫,後續我們還會介紹更多優美的 JS 函數式編程庫!
(俗話說的好,三方庫選的好,下班都很早!!)
現在本瓜有點明白那句話了:看一門語言是不是函數式編程,取決於它的核心庫是不是函數式編程。
也許我們還不熟悉像 RxJS 這類庫,但我們慢慢就會越來越重視它們,越來越使用它們,越來越領會到它們!!
非同步,以上。