Bleeding Edge Web: February 2020
News From the Bleeding Edge
— Brian Moeskau (@bmoeskau)
A CLI-First Approach to Web Development
— Corey Butler (@goldglovecb)
TypeScript In-Depth
— Ted Patrick (@__ted__)
Housekeeping
- Speakers and sponsors always wanted
- Join us on Slack
News from the
Bleeding Edge
Browser Pop Quiz
Last check January 21, 2020:
Browser Pop Quiz
As of February 25, 2020:
Chrome 80
data:image/s3,"s3://crabby-images/ba7dd/ba7dd48ccc5a4551f9fc69c4077e484fe39dcb7a" alt="Chrome"
PWA-related Origin Trial Graduates
Periodic Background Sync API
Sync your web app's data in the background for a more native-like experience
getInstalledRelatedApps()
Allows your web app to check whether your native app is installed on a user's device, and vice versa.
Chrome 80
data:image/s3,"s3://crabby-images/ba7dd/ba7dd48ccc5a4551f9fc69c4077e484fe39dcb7a" alt="Chrome"
JS Optional Chaining
Old:
let nameLength;
if (db && db.user && db.user.name)
nameLength = db.user.name.length;
New:
const nameLength = db?.user?.name?.length;
Edge 80
data:image/s3,"s3://crabby-images/8877c/8877caa423f20a31ec696b04c7e103436536c681" alt="Edge"
Released February 7th — Release Notes
- Updated to Chromium 80
- Various Windows-specific users features
Firefox 73
data:image/s3,"s3://crabby-images/6ac45/6ac457fbbd45d6ab50be6cf27448fd45f6e0b1fa" alt="Firefox"
Released February 11th — Release Notes
- Pretty minor release, nothing too interesting
- v74 Note: TLS 1.0 & 1.1 support will be removed (~March 10)
Languages, Libraries &
Frameworks
A typeface for developers
Released January 15th
- Another code-focused mono typeface (also see FiraCode)
- Increased height, 138 code-specific ligatures
data:image/s3,"s3://crabby-images/c6dc3/c6dc3262537a830500e9d485ac8bbd7a85891ab6" alt="JetBrains Mono"
Angular 9
data:image/s3,"s3://crabby-images/3357c/3357c0785515900887abcda42bfa5e943c591d71" alt="Angular"
Released February 6th — release notes
- New Ivy Compiler and runtime (huge bundle reductions)
- New YouTube and Google Maps components
- Component harnesses for testing components
- TypeScript 3.7 support
Ionic 5
data:image/s3,"s3://crabby-images/6fb9a/6fb9a0c9a6cb493808f7f04a248f0cd6b9a122a6" alt="Ionic"
Released February 11th — release notes
- iOS 13 design updates
- Angular Ivy support (plus React and Vue)
- New starter projects, colors, icons and more
data:image/s3,"s3://crabby-images/306a6/306a656d75dced78e0bb881f1e64a1d6493a6125" alt="Ionic components"
a Ruby on Rails equivalent for monolithic fullstack React apps
Announced February 17th — thread (not public yet)
- Claims to be "Rails good parts + React good parts"
- Eliminate all boilerplate and grunt work
- Still vaporware! But coming soon...
GitHub CLI
Supercharge your command line GitHub experience
data:image/s3,"s3://crabby-images/0e8cb/0e8cb62fd16cad94724d310b4e8f77d2c09aff01" alt="GitHub CLI"
文言 wenyan-lang
A programming language for the ancient Chinese
data:image/s3,"s3://crabby-images/3615a/3615ad8e60d9c099240fd2ab5e1da0dec6a0f363" alt="wenyan-lang"
Git Command Explorer
Find the right commands you need without digging through the web.
data:image/s3,"s3://crabby-images/53df2/53df2916f50dea67ce9d23a3a9bee31f6cd4b9af" alt="Git command explorer"
.org Registry Sale Paused
The $1.1B sale to Ethos Capital was announced last November
- People are not happy
- Internet Society advisory council is now reconsidering
- ICANN is reviewing the deal and could halt it
DNSSEC Key Signing Postponed
One of two secure safes malfunctioned
data:image/s3,"s3://crabby-images/2b854/2b85446e4e7e33afbdb346b344802417206f0157" alt="Signing ceremony"
Npm Outage Feb 17th
Caused by a Cloudflare DDoS protection bug
- Cloudflare tweaked HTTP header rules to identify bad traffic
- Npm uses a non-standard "install" referer
- Cloudflare started treating npm installs as DDoS attacks on npm!
- They reverted, but npm was basically down for 2 hours
Great reminder to prepare for such things
An Interesting Bug
- In 2018, Docker and Razer Synapse could not run together
- Each program intended to limit to one running copy of itself
- They both did something like this:
string.Format("Global\{0}", (object) Assembly.↵
GetExecutingAssembly().GetType().GUID);
Can you spot the bug?An Interesting Bug
string.Format("Global\{0}", (object) Assembly.↵
GetExecutingAssembly().GetType().GUID);
.GetType() returns .NET's System.Reflection.RuntimeAssembly
- So each app was sharing .NET's GUID
- Apparently this was from a flawed StackOverflow answer
- Beware the uncritical copy/paste!
VueConf 2020
data:image/s3,"s3://crabby-images/ed03c/ed03c529ea87e6aad9f5e17e46753098d64b2125" alt="VueConf"
And now for something completely different...
A 100% Solar-powered Website
data:image/s3,"s3://crabby-images/91bad/91badc7ee6a070b1f742bafa99c02dcdf62391ed" alt="Solar website"
Responsive Pixel Art
- Responsive design via SVG
- Check out the demo
data:image/s3,"s3://crabby-images/525f2/525f2a2024c0426bff3e907ef8ac0e6a322daf5d" alt="Pixel art"
Gif Peanut Butter
Perfect for sandwiches, baking, and shutting down internet debates
data:image/s3,"s3://crabby-images/20dde/20ddeb2c3af46310777cc5db60576cea69bdb8a7" alt="Gif peanut butter"
Gif Peanut Butter
data:image/s3,"s3://crabby-images/ca2b2/ca2b26adc475f1d463ed856b3d213b89cd80ecd4" alt="Gif peanut butter"
Thanks!
←→ /
#