摘要:前端每周清單第期現(xiàn)狀分析與優(yōu)化策略單元測(cè)試爬蟲(chóng)作者王下邀月熊編輯徐川前端每周清單專(zhuān)注前端領(lǐng)域內(nèi)容,以對(duì)外文資料的搜集為主,幫助開(kāi)發(fā)者了解一周前端熱點(diǎn)分為新聞熱點(diǎn)開(kāi)發(fā)教程工程實(shí)踐深度閱讀開(kāi)源項(xiàng)目巔峰人生等欄目。
前端每周清單第 29 期:Web 現(xiàn)狀分析與優(yōu)化策略、Vue 單元測(cè)試、Headless Chrome 爬蟲(chóng)
作者:王下邀月熊 編輯:徐川
前端每周清單專(zhuān)注前端領(lǐng)域內(nèi)容,以對(duì)外文資料的搜集為主,幫助開(kāi)發(fā)者了解一周前端熱點(diǎn);分為新聞熱點(diǎn)、開(kāi)發(fā)教程、工程實(shí)踐、深度閱讀、開(kāi)源項(xiàng)目、巔峰人生等欄目。歡迎關(guān)注【前端之巔】微信公眾號(hào)(ID:frontshow),及時(shí)獲取前端每周清單。
新聞熱點(diǎn)國(guó)內(nèi)國(guó)外,前端最新動(dòng)態(tài)
Prettier 1.6.0 發(fā)布:本周發(fā)布的 Prettier 1.6.0 版本引入了數(shù)個(gè)期待已久的特性,包括 .prettierrc,.prettierignore 項(xiàng)目配置文件、JSX 顯示格式優(yōu)化、允許 JSON 文件添加自定義注釋等;除此之外,該版本還進(jìn)一步優(yōu)化了對(duì)于 JavaScript、TypeScript、CSS、GraphQL 等格式文件的支持,還提供了更多的命令行特性。
Firefox 引入 Headless 模式:類(lèi)似于 Chrome 的 Headless 模式,現(xiàn)在 Firefox 也引入了 Headless 模式,其允許開(kāi)發(fā)者利用 Firefox 進(jìn)行更加方便地自動(dòng)化測(cè)試、動(dòng)態(tài)網(wǎng)頁(yè)抓取等操作;本文也介紹了如何利用 Selenium 控制 Firefox 進(jìn)行自動(dòng)化瀏覽器操作等內(nèi)容。
Webpack 4 開(kāi)發(fā)計(jì)劃:本文討論了 Webpack 4 相關(guān)的規(guī)劃與目標(biāo),在先前發(fā)布的 Webpack 3 版本中并未引入什么斷層變化,但是 Webpack 4 中會(huì)引入些重大的變革。Webpack 4 的主要目標(biāo)包括 WASM 支持、新的 CSS 工作流、支持 async script 標(biāo)簽、性能提升、繼續(xù)優(yōu)化 ESM、更加完善地支持類(lèi)型系統(tǒng)等。
TypeScript 2.5 版本發(fā)布:近日發(fā)布的 TypeScript 2.5 版本中引入了許多新的特性,并且能夠更好地與 VSCode 協(xié)同開(kāi)發(fā)。該版本中提供了函數(shù)與方法抽取重構(gòu)、快速類(lèi)型修復(fù)、JavaScript 文件中的 JSDoc 類(lèi)型斷言支持、可選的 catch 語(yǔ)句等特性,同時(shí)還進(jìn)一步優(yōu)化了性能與使用體驗(yàn)。
開(kāi)發(fā)教程步步為營(yíng),掌握基礎(chǔ)技能
基于 Node.js 的 HTTP2 服務(wù)端推送:Node.js 8.4.0 版本中引入了實(shí)驗(yàn)性的 HTTP/2 支持,開(kāi)發(fā)者可以通過(guò) --expose-http2 標(biāo)識(shí)位啟用 HTTP/2 支持。本文首先介紹了 HTTP/2 服務(wù)端推送中重要的知識(shí)點(diǎn),然后從零開(kāi)始創(chuàng)建簡(jiǎn)單的 Node.js 應(yīng)用,來(lái)形象闡述如何使用 HTTP/2 以及其特性;更多 HTTP/2 相關(guān)資料參考這里。
使用官方 Vue.js 測(cè)試工具與 Jest 編寫(xiě)組件的單元測(cè)試:Vue.js 以其靈活、高性能、易上手的特性正逐步被應(yīng)用到更多的 Web 項(xiàng)目中,本系列文章則著眼于介紹 Vue.js 應(yīng)用開(kāi)發(fā)中的單元測(cè)試相關(guān)內(nèi)容。本系列文章依次介紹了編寫(xiě)首個(gè)簡(jiǎn)單的組件單元測(cè)試用例、測(cè)試遞歸渲染的 Vue.js 組件、測(cè)試組件的樣式與結(jié)構(gòu)、測(cè)試組件的狀態(tài),計(jì)算屬性與方法、測(cè)試屬性與自定義事件、測(cè)試生命周期回調(diào)、測(cè)試 Vue.js Slots、利用模塊別名配置 Jest 等內(nèi)容;更多 Vue.js 相關(guān)資料參考這里。
利用 Service Worker 離線運(yùn)行 Angular 應(yīng)用:本文主要討論如何通過(guò) Service Worker 為 Angular 應(yīng)用添加離線運(yùn)行特性。本文首先介紹了 Service Worker 的概念與原理,然后介紹了 Google 提供的工具集 Workbox,以及如何使用 Workbox 創(chuàng)建簡(jiǎn)單的 Service Worker,最后以簡(jiǎn)單的應(yīng)用說(shuō)明了如何創(chuàng)建自定義的 Service Worker、選定緩存內(nèi)容與緩存策略。更多 Angular 相關(guān)資料參考這里。
60 分鐘內(nèi)構(gòu)建 Github 搜索欄:本文是來(lái)自 Appbase.io 的工程師分享的,如何快速構(gòu)建漂亮大方的 Github 應(yīng)用搜索界面。本文中使用 React 開(kāi)發(fā)前端界面,依次闡述了如何按照組件來(lái)切割界面、如何從底向上依次構(gòu)建各級(jí)所需要的組件、如何添加組件事件響應(yīng)、如何通過(guò) Github API 獲取數(shù)據(jù)并且渲染到界面上等內(nèi)容;更多 React 相關(guān)資料參考這里。
工程實(shí)踐立足實(shí)踐,提示實(shí)際水平
基于 Puppeteer 與 Chrome Headless 的網(wǎng)頁(yè)抓取:Puppeteer 是 Google Chrome 團(tuán)隊(duì)發(fā)布的 Chrome Headless 官方工具。而隨著 Chrome Headless 的發(fā)布,包括 PhantomJS、Selenium Firefox 等在內(nèi)很多的項(xiàng)目都宣布停止開(kāi)發(fā);Chrome Headless 正逐步成為 Web 應(yīng)用自動(dòng)化測(cè)試的行業(yè)領(lǐng)袖。而本文則是一步一步地介紹了如何利用 Chrome Headless、Puppeteer、Node 以及 Mongodb 來(lái)抓取 Github 上的相關(guān)內(nèi)容;更多 Chrome Headless 相關(guān)資料參考這里。
V8 中對(duì)象屬性的快速訪問(wèn):本文將會(huì)介紹 V8 引擎是如何處理 JavaScript 對(duì)象中屬性的機(jī)制;雖然在使用層面上字符型鍵與數(shù)值型鍵并無(wú)差異,但是 V8 處于性能與內(nèi)存的考慮會(huì)使用不同的方式來(lái)處理這兩種屬性。本文則會(huì)介紹 V8 提供的快速屬性訪問(wèn)機(jī)制與動(dòng)態(tài)屬性的處理,理解 inline caches 的運(yùn)行機(jī)制等內(nèi)容;更多 V8 相關(guān)資料參考這里。
基于 Webpack 的 Vue.js 應(yīng)用代碼分割:早期利用 Webpack 打包前端應(yīng)用的一大缺陷在于其會(huì)產(chǎn)生較大的包體,而后來(lái)引入的代碼分割特性則能有效地提升首屏加載速度。本文介紹了 Vue.js 應(yīng)用開(kāi)發(fā)中,如何利用 Webpack 與 Async components 來(lái)進(jìn)行代碼的動(dòng)態(tài)加載;更多 Vue.js 相關(guān)資料參考這里
SparkUI:FreeWheel 的 React 開(kāi)發(fā)實(shí)踐:SparkUI 是由 FreeWheel 根據(jù)自身業(yè)務(wù)特點(diǎn)開(kāi)發(fā)的一套完整且靈活的前端開(kāi)發(fā)解決方案。該方案基于 React,由 Modula 應(yīng)用狀態(tài)管理框架、一系列可重用的前端組件、以及構(gòu)建 SPA 所需的各類(lèi)支持庫(kù)組成。 該方案重視可重用性、靈活性、可測(cè)試性以及開(kāi)發(fā)效率,解決了前端社區(qū)常見(jiàn)的一些針對(duì)商業(yè)前端應(yīng)用開(kāi)發(fā)的痛點(diǎn),如復(fù)雜狀態(tài)、Side Effect,組件拆分等,更在工程實(shí)踐、文檔化、本身代碼質(zhì)量等方面達(dá)到較高標(biāo)準(zhǔn),為前后端分離架構(gòu)下的商業(yè)前端應(yīng)用開(kāi)發(fā)提供了堅(jiān)實(shí)的基礎(chǔ)。目前 SparkUI 已成功應(yīng)用在 FreeWheel 的前端項(xiàng)目中。
深度閱讀深度思考,升華開(kāi)發(fā)智慧
為什么我們從 Angular 2 遷移到了 Vue.js(以及為什么不用 React):本文是來(lái)自 Rever 的工程師分享的他們?cè)跇?gòu)建新版本 Web 應(yīng)用時(shí)技術(shù)選型的考量。作者主要從易用性、代碼運(yùn)行速度、文檔、社區(qū)活躍度、移動(dòng)端的支持、開(kāi)源協(xié)議等多個(gè)角度對(duì)比分析了 Angular.js、Vue.js 與 React 這三個(gè)主流框架。其中 Angular.js 的缺陷在于版本更迭過(guò)快、代碼執(zhí)行速度略慢、響應(yīng)式不足等方面;React 的代碼運(yùn)行速度一般,其最近的證書(shū)風(fēng)波也是令人遲疑,而 Vue.js 目前的主要缺陷在于其社區(qū)還不如 React 與 Angular 龐大。更多 Vue.js 相關(guān)資料參考這里
Web 的現(xiàn)狀:網(wǎng)頁(yè)性能提升指南:隨著因特網(wǎng)的快速發(fā)展,至今已有約 46% 的人們可以通過(guò)設(shè)備接入到網(wǎng)絡(luò)中;而其中的大多數(shù)又是通過(guò)移動(dòng)設(shè)備來(lái)瀏覽網(wǎng)頁(yè)或其他操作。本文即是對(duì)目前 Web 發(fā)展現(xiàn)狀進(jìn)行概要性描述,并且討論了當(dāng)前狀態(tài)下網(wǎng)頁(yè)應(yīng)該關(guān)注的性能提升點(diǎn)。本文依次分析了如何優(yōu)化 JavaScript、CSS 等資源文件、選擇合適的圖片、優(yōu)化網(wǎng)頁(yè)字體、優(yōu)化 JavaScript 執(zhí)行、如何正確地追蹤性能指標(biāo)等內(nèi)容;更多 Web 性能優(yōu)化相關(guān)資料參考這里。
Webkit 中 JavaScript 并發(fā)編程提案:隨著 SharedArrayBuffer 被引入,JavaScript 也正逐步轉(zhuǎn)向提供并發(fā)支持;本文即是 Webkit 開(kāi)發(fā)團(tuán)隊(duì)分享的它們對(duì)于并發(fā) JavaScript 編程的考慮與設(shè)計(jì)。本文依次討論了 Thread 相關(guān)的 API、JavaScript 內(nèi)存模型、如何與 DOM 進(jìn)行交互、如何進(jìn)行并發(fā)控制以及 WebKit 的實(shí)現(xiàn)方案等內(nèi)容;
澄清對(duì) AMP 的十個(gè)誤解:AMP 是由 Google 出品的,采用了白名單強(qiáng)約定策略的開(kāi)源 Web 組件格式和類(lèi)庫(kù);因?yàn)?AMP 本身處于性能的考慮限制了網(wǎng)頁(yè)本身的開(kāi)發(fā)自由,也導(dǎo)致了開(kāi)發(fā)者對(duì) AMP 頗有微詞。本文則是對(duì)于 AMP 的常見(jiàn)誤解進(jìn)行闡述,包括 AMP 的定位與運(yùn)行環(huán)境、AMP 的適用目標(biāo)、AMP 與現(xiàn)有網(wǎng)站的集成方式、AMP 與 PWA 之間的關(guān)系等內(nèi)容。
開(kāi)源項(xiàng)目樂(lè)于分享,共推前端發(fā)展
asm-dom: asm-dom 是輕量級(jí)的基于 WebAssembly 的 Virtual DOM 框架,其允許開(kāi)發(fā)者使用 C++ 來(lái)構(gòu)建 Web 單頁(yè)應(yīng)用。開(kāi)發(fā)者可以僅使用 C++ 來(lái)編寫(xiě) Web 應(yīng)用,然后通過(guò) Emscripten 來(lái)將其轉(zhuǎn)化為 WebAssembly;其能允許開(kāi)發(fā)者直接使用現(xiàn)有的 C++ 標(biāo)準(zhǔn)庫(kù)代碼,從而保證代碼復(fù)用與性能提升。
Vivify:Vivify 是輕量級(jí)的 CSS 動(dòng)畫(huà)庫(kù),提供了數(shù)十種常見(jiàn)的 CSS 動(dòng)畫(huà)實(shí)現(xiàn),包括 ball、blink、driveInBottom、fadeIn、flip、popIn 等;開(kāi)發(fā)者只需要將樣式文件引入頁(yè)面中即可使用。
React Map GL:React Map GL 是 Uber 出品的基于 React 與 Mapbox GL 的地圖庫(kù),其提供了 Browserify、Webpack 2、create-react-app 多種集成嘗方式;官方也給出了與 Redux 的便捷集成方式。
Push: Push 是 BrowserStack 出品的,快速實(shí)現(xiàn)基于 JavaScript 的桌面消息推送工具;Push 能夠自動(dòng)利用 Chrome、Safari、Firefox、IE9+ 這些現(xiàn)代瀏覽器提供的底層接口,為開(kāi)發(fā)者提供跨平臺(tái)的統(tǒng)一調(diào)用方式。
r2:r2 是 request 的作者基于多年的現(xiàn)代開(kāi)發(fā)實(shí)踐總結(jié)出的輕量級(jí)、高可用 HTTP 客戶端;r2 基于瀏覽器端的 fetch 實(shí)現(xiàn),使用了 node-fetch 提供了 Node.js 環(huán)境下的支持。
巔峰人生與 Node.js 創(chuàng)立者 Ryan Dahl 的對(duì)話:Ryan Dahl 是 Google Brain 團(tuán)隊(duì)的軟件工程師,也是 Node.js 項(xiàng)目的創(chuàng)立者;而他目前則就職于深度學(xué)習(xí)項(xiàng)目,著手圖片轉(zhuǎn)化等相關(guān)的方向。本文則是與 Ryan Dahl 的一次訪談?dòng)涗洠務(wù)摿?Ryan Dahl 的技術(shù)生涯發(fā)展、工作選擇、創(chuàng)立 Node.js 的考量等內(nèi)容。
前端之巔「前端之巔」是InfoQ旗下關(guān)注前端技術(shù)的垂直社群,加入前端之巔學(xué)習(xí)群請(qǐng)關(guān)注「前端之巔」公眾號(hào)后回復(fù)“加群”。投稿請(qǐng)發(fā)郵件到editors@cn.infoq.com,注明“前端之巔投稿”。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/87432.html
摘要:感謝王下邀月熊分享的前端每周清單,為方便大家閱讀,特整理一份索引。王下邀月熊大大也于年月日整理了自己的前端每周清單系列,并以年月為單位進(jìn)行分類(lèi),具體內(nèi)容看這里前端每周清單年度總結(jié)與盤(pán)點(diǎn)。 感謝 王下邀月熊_Chevalier 分享的前端每周清單,為方便大家閱讀,特整理一份索引。 王下邀月熊大大也于 2018 年 3 月 31 日整理了自己的前端每周清單系列,并以年/月為單位進(jìn)行分類(lèi),具...
摘要:前端每周清單年度總結(jié)與盤(pán)點(diǎn)在過(guò)去的八個(gè)月中,我?guī)缀踔蛔隽藘杉拢ぷ髋c整理前端每周清單。本文末尾我會(huì)附上清單線索來(lái)源與目前共期清單的地址,感謝每一位閱讀鼓勵(lì)過(guò)的朋友,希望你們能夠繼續(xù)支持未來(lái)的每周清單。 showImg(https://segmentfault.com/img/remote/1460000010890043); 前端每周清單年度總結(jié)與盤(pán)點(diǎn) 在過(guò)去的八個(gè)月中,我?guī)缀踔蛔隽?..
摘要:工程實(shí)踐立足實(shí)踐,提示實(shí)際水平內(nèi)聯(lián)函數(shù)與性能很多關(guān)于性能優(yōu)化的文章都會(huì)談及內(nèi)聯(lián)函數(shù),其也是常見(jiàn)的被詬病為拖慢性能表現(xiàn)的元兇之一不過(guò)本文卻是打破砂鍋問(wèn)到底,論證了內(nèi)聯(lián)函數(shù)并不一定就會(huì)拖慢性能,過(guò)度的性能優(yōu)化反而會(huì)有損于應(yīng)用性能。 showImg(https://segmentfault.com/img/remote/1460000011481413?w=1240&h=825); 前端每周...
摘要:發(fā)布是由團(tuán)隊(duì)開(kāi)源的,操作接口庫(kù),已成為事實(shí)上的瀏覽器操作標(biāo)準(zhǔn)。本周正式發(fā)布,為我們帶來(lái)了,,支持自定義頭部與腳部,支持增強(qiáng),兼容原生協(xié)議等特性變化。新特性介紹日前發(fā)布了大版本更新,引入了一系列的新特性與提升,本文即是對(duì)這些變化進(jìn)行深入解讀。 showImg(https://segmentfault.com/img/remote/1460000012940044); 前端每周清單專(zhuān)注前端...
閱讀 1221·2021-09-26 09:55
閱讀 3183·2019-08-30 15:55
閱讀 961·2019-08-30 15:53
閱讀 2291·2019-08-30 13:59
閱讀 2377·2019-08-29 13:08
閱讀 1104·2019-08-29 12:19
閱讀 3299·2019-08-26 13:41
閱讀 416·2019-08-26 13:24