前端排序算法總結;前端面試題2.0;JavaScript異步編程

編程語言 JavaScript HTML5 DNS 前端開發學習 前端開發學習 2017-09-25

前端排序算法總結;前端面試題2.0;JavaScript異步編程

1、前端 排序算法總結

排序算法可能是你學編程第一個學習的算法,還記得冒泡嗎? 當然,排序和查找兩類算法是面試的熱門選項。如果你是一個會寫快排的程序猿,面試官在比較你和一個連快排都不會寫的人的時候,會優先選擇你的。那麼,前端需要會排序嗎?答案是毋庸置疑的,必須會。現在的前端對計算機基礎要求越來越高了,如果連排序這些算法都不會,那麼發展前景就有限了。本篇將會總結一下,在前端的一些排序算法。

https://segmentfault.com/a/1190000011294349

2、前端面試題 V2.0

詳見: 這是一份集合了多家公司面試題的問答列表,涵蓋底層原理、網絡知識、性能優化等眾多方面的內容,旨在幫助中、高級前端工程師檢測知識點掌握情況,瞭解面試的各種套路。

http://hawx1993.github.io/Front-end-Interview-Questions/#/

3、JavaScript 與 異步編程

按照維基百科上的解釋:獨立於主控制流之外發生的事件就叫做異步。因為 setTimeout 的存在,至少在被 ECMA 標準化的那一刻起,JavaScript 就支持異步編程了。與其他語言的 sleep 不同,setTimeout 是異步的——它不會阻擋當前程序繼續往下執行。然而異步編程真正發展壯大,Ajax 的流行功不可沒。Ajax 中的 A(Asynchronous)真正點到了異步的概念——這還是 IE5、IE6 的時代。

https://segmentfault.com/a/1190000011296630

4、html2canvas將HTML內容寫入Canvas生成圖片

html2canvas 能夠實現在用戶瀏覽器端直接對整個或部分頁面進行截屏。這個html2canvas腳本將當前頁面渲染成一個canvas圖片,通過讀取DOM並將不同的樣式應用到這些元素上實現。 #前端開發博客#

http://caibaojian.com/html2canvas.html

5、優酷 HTML5 播放器擴展:Youku-HTML5-Player

Youku-HTML5-Player 是一個 Youku HTML5 播放器擴展,幫助你從此告別 Flash 和廣告。同時,它具備智能記憶、彈幕、視頻下載等功能。

https://github.com/esterTion/Youku-HTML5-Player

6、jquery點擊滑動到某個位置

點擊向下滾動到某個位置,比較常用的一個功能,只需要一個簡單的函數就可以滑動到任意你需要的地方,默認點擊之後是返回頂部。

http://caibaojian.com/jquery-scrollto.html

7、JavaScript 在 V8 中的元素種類及性能優化

JavaScript 對象可以具有與它們相關聯的任意屬性。對象屬性的名稱可以包含任何字符。JavaScript 引擎可以進行優化的一個有趣的例子是當屬性名是純數字時,一個特例就是數組索引的屬性。 在 V8 中,如果屬性名是數字(最常見的形式是 Array 構造函數生成的對象)會被特殊處理。儘管在許多情況下,這些數字索引屬性的行為與其他屬性一樣,V8 選擇將它們與非數字屬性分開存儲以進行優化。在引擎內部,V8 甚至給這些屬性一個特殊的名稱:元素。對象具有映射到值的屬性,而數組具有映射到元素的索引。

https://segmentfault.com/a/1190000011303679

8、前端分享之cookie的使用及單點登錄

cookie的英文意思是餅乾。在計算機術語中指服務端存放在客戶端的一段數據。這段數據在客戶端每次進行http請求時會自動加在http請求報文中的header上;服務端在響應時,可以對cookie進行設置,並將cookie加入到http響應報文header中。MDN中對cookie的解釋為:cookie 是一個請求首部,其中含有先前由服務器通過 Set-Cookie 首部投放並存儲到客戶端的 HTTP cookies。 cookie一般存放在對應的域名下,各個瀏覽器對中一個域名下存放的cookie的個數與大小規定不一樣。下表是不同瀏覽器對cookie存放的規定:

https://segmentfault.com/a/1190000011295587

9、使用Node.js瞭解和測量HTTP花費的時間

瞭解和測量HTTP時間有助於我們發現客戶端到服務器或服務器到服務器之間的通信性能瓶頸。 本文介紹了HTTP請求中的時間開銷,並展示瞭如何在Node.js中進行測量。 DNS查找:執行DNS查找所花費的時間。 DNS查找將域名解析為IP地址。 每個新的域需要一個完整的往返行程來進行DNS查找。 當目的地已經是IP地址時,沒有DNS查找。 TCP連接:在源主機和目標主機之間建立TCP連接所需的時間。 必須在多步握手過程中正確建立連接。 TCP連接由操作系統管理,如果基礎TCP連接無法建立,則OS範圍的TCP連接超時將會進入我們應用程序中的超時配置。 TLS握手:完成TLS握手的時間。 在握手過程中,端點交換認證和密鑰以建立或恢復安全會話。 沒有HTTPS請求的不需要TLS握手。 第一個字節的時間(TTFB):等待初始響應的時間。 此時間除了等待服務器處理請求和傳遞響應所花費的時間之外,還可以捕獲往返服務器的延遲。 內容傳輸:接收響應數據所花費的時間。 響應數據的大小和可用的網絡帶寬決定其持續時間。

https://segmentfault.com/a/1190000011299825

喜歡這篇文章的朋友,歡迎關注、收藏、分享、評論,幫我上熱門,你的支持,是我每日更新的動力!

今日更多精彩文章:http://caibaojian.com/fe-daily-20170923.html

喜歡前端的朋友可以點擊關注一下我,每日分享精彩的前端文章!

相關推薦

推薦中...