前端之道:React组件解耦之道;基于Headless Chrome的自动化测试;Angular 2/4是否为时已晚?

作者|王下邀月熊

                                       新闻热点

国内国外,前端最新动态

TypeScript 2.4 发布:TypeScript 是提供了静态类型和很多先进特性的 JavaScript 语言超集;而在最新发布的 2.4 版本中,新增了动态 import 语法、字符串枚举类型等特性,并且提高了泛型推导等功能。( https://parg.co/bem )

Node v8.1.3 发布:近日发布的 Node v8.1.3 版本包含了一系列的错误修复与文档内容提升。( https://nodejs.org/en/blog/release/v8.1.3/ )

Preact CLI 1.3.0 发布:Preact CLI 是快速创建 Preact 应用的工具,在近日发布的 Preact CLI 1.3.0 版本中,开发者可以自定义 Webpack 配置文件与 .babelrc 配置文件。该版本还转向了使用 Webpack 进行预渲染,同时还修复了之前版本遗留的一系列错误;最后该版本还引入了完整的测试用例以提高整个代码的鲁棒性。( https://parg.co/bXx )

MDN 被 Mozilla 重造,将更关注 Web 文档:MDN 的权威性以及文档的高质量一直广受 Web 开发人员的认可,开发人员在搜索 HTML 和 JavaScript 的文档时,通常会发现 MDN 的点击率很高。基于此,Mozilla 决定“押宝”在提升 Web 文档体验,正式宣布将使 MDN 的工作重心侧重于 Web 文档。( https://parg.co/bXT )

Twitter Lite PWA 显著提升用户活跃度并且降低了数据流量:Twitter 是主要的社交网络平台之一,其 80% 的用户访问来源于移动端。为了提高移动端网页版体验效果,Twitter 整合了现代 Web 与原生特性的优点,开发了 Twitter Lite Progressive Web App,并且在四月份正式面向所有用户开放。而近日统计数据显示新版本网页带来了 65% 的用户停留时长提升、75% 的用户发文提升与 20% 的回退率降低。( https://parg.co/bX7  )

                                        开发教程

步步为营,掌握基础技能

基于 Headless Chrome 的自动化测试:本文介绍了如何在 Headless Chrome 环境中使用 Karma 作为测试驱动运行基于 Mocha 与 Chai 的自动化测试用例。Headless Chrome 允许我们在无界面环境下,使用特性完备的 Chrome 来执行 JavaScript 脚本并且渲染网页。本文首先介绍了使用 karma-chrome-launcher 来搭建本地启动 Chrome 环境,然后介绍了使用 Mocha 与 Chai 来编写基础测试用例,最后还讨论了如何自定义 Headless Chrome 启动器并且集成到 Travis CI 环境下。( https://parg.co/beo )

Angular 2+ 项目实战系列:本系列文章包含了八个不同的章节,从零开始介绍如何利用 MongoDB、Express、Angular 2+ 以及 Node.js(MEAN Stack)来构建某个真实的应用项目。第一部分着眼于进行基础环境的搭建,包括搭建 Angular 应用开发环境、本地搭建 MongoDB、在 Auth0 申请账户与开发者密钥、搭建 Node.js 服务器并且为 Angular 应用添加基础的组件等等。第二部分着眼于添加基础的权限验证功能,并且构建数据模型等。 ( https://parg.co/beA )

利用树莓派、Node 与 React 打造智能家居:作者自小就喜欢倒腾电路与计算机,而本文则简要记述了作者如何利用树莓派来将自己的电子家居变得智能可控。作者主要是由了 React Native 来开发客户端应用,并且通过 WebSocket 来与 NodeJS 后端进行数据通信,并且使用pi-blaster与wiringPi等库来保证 NodeJS 后端控制树莓派并且获取实时数据。另一方面,作者利用树莓派作为中控枢纽,分别将其连接到不同的控制器中,作者在本文中还给出了详细的电路图设计,全部的代码参考 这里。( https://parg.co/bXB )

VueConf 观后感:首届官方举办的 Vue.js 大会刚刚落幕,本文即是作者对于自己参会之后的感想进行的简要阐述。作者首先介绍了自己参与的数个 WorkShop 与演讲,从 Evan You 对于 Vue.js 发展历史与现状的介绍,到基于 Vuex 的状态管理、服务端渲染、代码分割等多个具体的技术实现。本文是非常不错的对于 VueConf 的回顾,如果没有参会或者尚未了解过议程的同学可以一看,并且选择自己感兴趣的议题查看对应的胶片与演讲视频。 ( https://parg.co/ber  )

Webpack 中的作用域提升简介:近日发布的 Webpack 3 中引入了所谓的 Scope Hoisting 新特性,从社区的反馈来看该特性已经在很多项目中成功地帮助开发者减少包体大小,提高首屏加载效率;本文则是简要地介绍了 Webpack 3 中作用域提升的基础原理。本文假设你对于 JavaScript 中闭包与模块语法有所了解,首先介绍了在老版本 Webpack 中采用的作用域分割机制及其存在的额外的性能损耗,然后对比呈现了在引入作用域提升机制之后,打包而成的文件的形式,与其带来的性能提升原理。( https://parg.co/beE )

                                         工程实践

立足实践,提示实际水平

React 组件解耦之道:React 的组件非常地灵活可扩展,不过随着业务复杂度的增加和许多外部工具库的引入,组件往往也会显得浮肿;作者在本文中阐述了常见的几种,遵循单一职责原则的,组件分割与解耦的方法。 本文首先介绍了基础的分割 render 函数的使用范式,然后讨论了将元素以属性方式传入,最后还介绍了部分高阶组件相关的用法与知识;更多 React 相关资料参考  https://parg.co/bM1 。( https://parg.co/bXz )

为什么我们选择 TypeScript:本文是 Reddit 工程师 Niranjan Ramadas 记述在前端技术选型时选用 TypeScript 的考虑过程。作者认为任何语言都有其优缺点,不过合适的语言应该具备如下特点:强类型、完备的工具链支持、能够用于生产环境等。作者还特地比较了 TypeScript 与 Flow,TypeScript 是能够编译到 JavaScript 的超集语言,而 Flow 则是提供了一系列额外的注解来实现类型系统。Flow 能够保证较好的类型覆盖,但是其对于多态性的支持并不是很好,并且 TypeScript 的社区也相对活跃。( https://parg.co/beb  )

基于 Prometheus 的 Node.js 应用性能监控:本文致力于帮助已有生产环境下 Node.js 应用的开发者,了解如何利用开源应用 Prometheus 搭建监测平台;Prometheus 为我们提供了强大的数据压缩与针对时序数据的快速查询功能。本文首先讨论了 Node.js 应用监控的设计理念与指标,然后对比了当前存在的几种监控解决方案的优缺点。最后介绍了如何在项目中引入 Prometheus,并且集成 Kubernetes、Grafana 等第三方插件;更多 Node.js 相关资料参考  https://parg.co/be0 。( https://parg.co/bed  )

我认为的 React Native 开发最佳实践分享:React Native 问世已愈两年,也为越来越多的团队用来开发性能表现不输原生的应用;尽管 React Native 还不算完全成熟(未发布 1.0 版本),但是围绕它已经产生了一个庞大的社区和许多的开发实践。作者编写本系列文章即是希望与大家共享个人在多年的 React Native 开发中总结而来最佳实践,第一篇文章首先介绍了 Redux 的概念与引入的积极意义,然后讨论了如何编写可复用的组件以及如何尽可能地提取公共代码与变量等内容;更多 React Native 相关资料参考  https://parg.co/bV4 。( https://parg.co/beC  )

                                         深度阅读

深度思考,升华开发智慧

选择与支持 Vue.js 的理由:本文是来自 Monterail 的前端工程师、Vue.js 资深开发者 Damian Dulisz 分享他选择与支持 Vue.js 的理由。本文不仅仅从开发者的角度阐述了 Vue.js 对其的吸引力,还从产品经理的视角、Vue.js 社区发展的角度阐述了 Vue.js 的巨大潜力。本文是一篇不错的介绍 Vue.js 最新变化与进展,并且对常见的 Vue.js 的部分误解进行了阐述的文章;更多 Vue 相关资料参考  https://parg.co/byL 。( https://parg.co/bX2 )

TC39,ECMAScript 与 JavaScript 的未来:本文是 Nicolás Bevacqua 在腾讯前端大会上发表的同名演讲的总结,介绍了 TC39 与 ECMAScript 的含义,概述了 ECMAScript 中提案的步骤以及部分代表性提案,同时还畅谈了 JavaScript 的未来发展方向。作者介绍了 Stage 0、Stage 1、Stage 2、Stage 3 这四个提案处理进度的具体含义与要求,并且列举了 Array#includes、Named Captures 等具体的例子来阐述 JavaScript 不断衍化的语法特性;作者还介绍了未来社区会持续关注的代码转译与适配、代码质量保证、代码打包与发布等多个领域。( https://parg.co/bXD )

为何 Angular 2/4 为时已晚(*本文仅代表原作者个人意见):时光回溯到 2012,那时的 Angular 还是不断崛起的前端新星;而在 2017 年里,当年的 Angular 已不能再满足 JS 生态对于完备性、灵活性与生产效率的要求。而 Angular 2/4 长达三年的开发周期、不向后兼容的架构要求让许多公司望而却步;作者在本文中首先回顾了 2012 年中 Angular 为何名噪一时,2013 年里 React 又是如何重塑了前端开发的技术栈与理念,2015 年里 React Native 的登场又带来了哪些变化,以及现代前端开发中如何使用 Webpack、NPM 这些工具辅助 React、Vue.js 这些轻量级的前端框架来维护大规模、可扩展的单页应用。( https://parg.co/bXn )

JavaScript 中的函数式编程就是反模式(* 本文仅代表原作者个人意见):作者在本文中对比讨论了 JavaScript 与 Clojure,并且介绍了 ClojureScript 的基础用法与优势所在。作者首先讨论了他认为的函数式脚本语言应该包含的特性,包括充分的 API、内建的不可变数据结构等;然后阐述了 lodash、fp、Rambda 这样的单个库存在的不足,譬如 ImmutableJS 虽然能较好地解决部分问题,但是却会割裂使用者的开发体验。最后笔者介绍了 ClojureScripe 的特性与优点,包括能够在编辑器中单行运行、内建的大量转化函数、较好地性能与代码可读性保证等等。( https://parg.co/beH  )

                                     开源项目

乐于分享,共推前端发展

bundlesize:bundlesize 是轻量级的用于检测项目打包生成包体体积的工具,可以方便地集成于 Travis CI、Circle CI 等持续集成工具中,以确保生成的库或者应用体积不会超过预期;目前 React、styled-components、emotion 等诸多流行库都已采用该工具。( https://github.com/siddharthkp/bundlesize )

kittenTricks:kittenTricks 是超过 40 屏的 React Native 应用开发中常见的精美界面集锦,包括应用加载、权限验证、社交资料、资讯浏览、聊天通信等多个领域。kittenTricks 还提供了内置的应用主题热加载,并且其本身的代码库也是相当干净整洁,值得一读。( https://github.com/akveo/kittenTricks  )

PicoGL.js:PicoGL.js 是基于 WebGL 2 的轻量级辅助库,适用于任何了解 WebGL 2 渲染管道流并且打算使用它的开发者。PicoGL.js 提高了更为方便地流式接口,典型的使用场景即是创建 Vertex Buffers、Vertex Arrays、FrameBuffers 等。( https://github.com/tsherif/picogl.js )

vue-table-component: vue-table-component 提供了轻量级、易于使用的 Vue.js 组件;该组件的一大特性在于其能够自动缓存用户的筛选与排序结果,即使用户刷新了页面该数据仍然可以保留使用。( https://github.com/spatie/vue-table-component  )

react-hold: react-hold 能够自动地为纯组件创建加载提示,它能够自动地根据纯组件不同的形状与类型创建不同的占位提示符。( https://github.com/toplan/react-hold )

                                        视野拓展

推荐一个超实用的前端周末培训,只要999,最新的前端技术包教包会。

【iTechPlus】 | 新前端实战营周末课程(Vue+Weex班)

【iTechPlus】 | 新前端实战营周末课程(react+react native班)

【iTechPlus】 | 新前端实战营周末课程(Nodejs+微信小程序班)

【iTechPlus】 | 新前端实战营周末课程(Nodejs班)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,028评论 25 707
  • 你就是这样的一个人我怎么猜也猜不透。女人的心思就像海底针,而你的心思就像那黑洞无形伸手抓不住你的心…… 我们的相识...
    不负过往人心阅读 241评论 0 1
  • 析构器只适用于类类型,当一个类的实例被释放之前,析构器会被立即调用。 析构过程原理 Swift 会自动释放不再需要...
    OrangeInce阅读 213评论 0 0