Yarn 作者手把手教你如何写一个包管理器,或许写出一个比 Yarn 更 NB 的工具呢。
TC39会议上,官方发布了 EcmaScript 8 或者叫做 EcmaScript 2017 正式版。最近几年,大家对 ESMA 的关注持续升温,标准的更新也走上了一年一版的正途,可你知道 ES5 哪年发布的么,2009年!是的,那是前端工程师这个称呼的元年。
另附:Pattern Matching in ECMAScript
Node.js 全版本安全更新现已可用。安全更新包含初始化声明中高危标识符,4版本中一个漏洞修复,同时也包含了近几个版本的小问题修复。
新版本 npm 中添加了一个 npx 的工具,让安装管理依赖更加轻松。另外,还可以一键完成命令行工具功能。
ES6中添加了很多 JavaScript 新特性,正则这边就有 /u
和 /y
等标识,本文详细介绍这些‘新’特性。
sphinx-js consumes standard JSDoc comments and tags—you don’t have to do anything weird to your source code. You just have Sphinx initialize a docs folder in the root of your project, activate sphinx-js as a plugin, and then write docs to your heart’s content using simple reStructuredText. When it comes time to call in some extracted documentation, you use one of sphinx-js’s special directives, modeled after the Python-centric autodoc’s mature example.
Fiber 是如何实现的
MVC 模式对于客户端框架来讲非常合适,但现代开发框架一直在演进,本文来探讨如何构造一个经久不衰的开发框架
事件委托是处理事件的通用手段,但是否所有项目都适用尚未可知。事实上,问题可同质为是否添加预置事件处理方式是合理的。解决是否合适的问题就需要对事务本身有深刻的认识。
本文是笔者多年来积累和收集的知识技能图谱,有的是笔者原创总结的最佳实践,有的是小伙伴们的分享,其中每个秘籍图谱里面的内容都是互联网高并发架构师应该了解和掌握的知识,笔者索性把这些图谱收集在一起,并且归类便于查找和学习,希望能够帮助到每一位想成为架构师或者已经是架构师的小伙伴。
HTTPS、MIP、AR 等相关的技术分享
在这篇文章里,我会先实现一个很常见的 MVC 架构,然后对状态和状态改变的部分进行抽象及重构,最终得到一个纯函数式的易于测试的 View Controller 类。希望通过这个例子,能够给你在日常维护 View Controller 的工作中带来一些启示或者帮助。
很详细的 UI 对比及说明
This is the first in a series of posts where we draw from our learnings to outline various aspects that we are addressing in the next generation of our platform. We believe these aspects are applicable to general purpose serverless solutions too. Here we will look at application development, delivery and code composition. Future posts will delve into topics such as deployments, insights, performance, scalability and other operational concerns.
Amsterdam JS Conference 2017 会议记录
如何分析一个高度混淆的代码,能学到不少知识
Scope, Architecture, DOM, Node.js…
I’ve always admired well-tested software projects, like SQLite, and aim to place Rust among the pantheon of the best. This document then, is a catalog of all the ways we test Rust. I hope it provides insight into what it takes to deliver a production-quality programming language, a hint at the wide variety of techniques employed in software validation, and that it reinforces your confidence in Rust’s reliability.
另附:Principles of Automated Testing
When you write your module (let’s say a Node JavaScript one), you often expose public API, but internally your code accesses the outside world via own code. Testing the public API is the best, but often it is hard, since your code interacts with the file system, user or network. How do you test the exposed API when you need to mock the rest of the system? I think it is preferable to NOT mock your own code modules, but to mock the interface to the external world.
SPAs are a good choice if: The interface you’re building is highly interactive and needs to be fast / responsive — and you want an architecture and abstractions that supports this out the gate; You’re not worried about each and every bit of content being indexed by search engines correctly. On the other hand, an SPA might not be worth the complexity if: Your application is simple (there’s not a lot of interactive content); SEO is of pivotal importance.
I submit to you that modern programming has little to do with the look of your desktop. Graphical user interfaces are only skin deep. Modern programming techniques are all about processes and actual tools, not the skin on top of them. I don’t care whether you are using Eclipse or Emacs… this tells me nothing about how modern you are. So what is “modern”?
文中给出了 UX 团队所交付的设计稿中的优秀部分。为了便于查阅,我将这些设计按照交付归类:用户调研,市场调研,设计,测试,每一个话题都有额外信息可以参考。
很多小伙伴花费大量的时间再 CSS 和 UX/UI 上边,忽略了网页的入口 URL,搞得又臭又长,有些甚至还很反人类。
Angular version 4.3 has been released. This is a minor release following our announced adoption of Semantic Versioning, meaning that it contains no breaking changes and that it is a drop-in replacement for 4.x.x.
Babylon.js is an open source framework that allows you to create stunning 3D experiences in your browser. Built with simplicity and performance in mind, it is the engine that fuels the Remix3D site or the Xbox Design Lab.
Tim Berners-Lee, the chief arbiter of Web standards, approved the controversial proposed Digital Restrictions Management (DRM) standard for the Web, Encrypted Media Extensions (EME).
We’re announcing Stack Overflow Channels for teams that need a dedicated, private space to share knowledge. We’re working hard on an early beta, and we want your active involvement in the product as we build it.
Our Enterprise Engineering team recently developed a software management script that could save teams hundreds of hours in building application packages for Mac users. The new system makes it easier for people to access Adobe apps with centrally-managed Creative Cloud licensing, while saving time and improving reporting and accounting accuracy.
emotion is a high performance, lightweight css-in-js library. The core idea comes from Sunil Pai’s glam library and its philosophy is laid out here. The basic idea is simple. You shouldn’t have to sacrifice runtime performance for good developer experience when writing CSS. emotion minimizes the runtime cost of css-in-js dramatically by parsing your styles with PostCSS during compilation instead of at runtime. 详见介绍文。
微信开源的 Sketch 辅助插件
pell is the simplest and smallest WYSIWYG text editor for web, with no dependencies
gpu.js is a single-file JavaScript library for GPGPU (General purpose computing on GPUs) in the browser. gpu.js will automatically compile specially written JavaScript functions into shader language and run them on the GPU using the WebGL API. In case WebGL is not available, the functions will still run in regular JavaScript.
p5.js is a JavaScript library that starts with the original goal of Processing, to make coding accessible for artists, designers, edcators, and beginners, and reinterprets this for today’s web.
A JavaScript framework to create conversational UIs.
TagUI is a general purpose tool for automating web interactions
CSS Database is a comprehensive list of CSS features and their positions in the process of becoming implemented web standards.
用纯CSS来制作几个海洋生物的样子,值得学习
最近我们有同事正好用过别的类似工具,语法和函数都好说,字符编码不一致的问题比较麻烦。另附:V8Py - Write Python APIs, then call them from JavaScript
收集了大量 React 项目,方便通过查找代码的方式学习
http://code.viget.com/microcosm/ Microcosm is Flux with actions at center stage. Write optimistic updates, cancel requests, and track changes with ease。附:官方介绍
In this post I’ll highlight tools and techniques for making React apps fast. Each section also has an interactive, and (hopefully) fun demo. Tools: The Performance Timeline, why-did-you-update, React Developer Tools.
Welcome to this great showcase of 21 web tools & services that are highly rated by experts. The used methods to find out the most popular solutions were to search the internet, test the web tools and discuss with different experts from several domains.
对6个比较火热的 Material Design 的CSS框架进行对比,用户可以根据自己的需求场景以及各个框架的生态情况选择适合自己的那一款
PouchDB is an open-source JavaScript database inspired by Apache CouchDB that is designed to run well within the browser. PouchDB was created to help web developers build applications that work as well offline as they do online.
Checklist of the most important security countermeasures when designing, testing, and releasing your API.
Redis 4.0.0 is out. I’m very happy about 4.0, because this release finally overcomes several very important limits of Redis. There are many things in the 4.2 plan, so Redis with 4.0 is not magically perfect. Yet it is a very important, measurable, step forward, because of the following features.
Go 语言已然跃进 TIOBE 前十,这是 Go 里程碑一样的大事件,当然你会关心 Go 到底能活多久,是否能甩 JavaScript/Python 几条街 [:嘲笑脸] 我们拭目以待。
产品及其它
A free app that narrates the world around you. Designed for the low vision community, this research project harnesses the power of AI to describe people, text and objects.
另附: Google - Using Deep Learning to Create Professional-Level Photographs Facebook - ELF: An extensive, lightweight and flexible platform for game research
在企业类应用服务(SaaS)、检测工具(手机安全助手)、量化自我工具(智能手环)等后台管理系统中,使用Dashboard可以帮助用户监控和分析数据,快速获取重要信息。但如果对Dashboard设计缺乏认知,就很可能会造成Dashboard呈现的信息杂乱,充斥着无关紧要的指标、文本信息及各种半成品的图表等,让用户抓不到重点。那么,设计师该如何设计内容精确、体验友好的Dashboard以满足用户需求呢?
技术连接了两个端,一端是需求、目的,另一端是一个已有的技术,将两者结合一起,商业贡献与技术贡献的有效结合形成化学反应,出现了一个新技术,而这个新技术再去满足新的技术,再出来一个新的技术,形成一个化学反应过程。如果团队成员每个人想法背景多元化,但梦想又相同时,会出现很多创新的结果,技术本身是化学反应不是物理反应。比团队认同自己更重要的是,认同共同的目标。最顺利的时候总是最危险的时候。今天很残酷,明天更残酷,但是后天很美好。
我们一定要有一个坚定不移的深刻的理念,相信整个世界终究是为技术所驱动的;有没有其他人已经解决这个问题?然后你可以把你的时间放在更好的创新上;做什么事情一定要做最好,一定要是做业界最强的;我把自己想象是一个软件、一个代码,今天的版本一定要比昨天版本好,明天的版本肯定会比今天好;看到问题也不要去问别人,就把它Fix。