Bleeding Edge Web: Feb 2019
News From the Bleeding Edge
— Brian Moeskau (@bmoeskau)
HomeAway's Multi-Cloud Traffic Director
— Andrew Hodges & Alex Mays
Thanks to our premiere sponsor:
Swag by Linkerd
A service mesh for Kubernetes and beyond
data:image/s3,"s3://crabby-images/cd336/cd33697dc71a9a9decd612853cc85618bf6536a2" alt="Linkerd"
Housekeeping
- Speakers and sponsors always wanted (edgeatx.org)
- Don't forget your parking validation
- Omni hotel bar (downstairs) after meetup
- Anyone hiring / looking?
News from the
Bleeding Edge
Browser Pop Quiz
Last check: January 17, 2019:
Browser Pop Quiz
As of February 21, 2019:
Chrome 72
data:image/s3,"s3://crabby-images/ba7dd/ba7dd48ccc5a4551f9fc69c4077e484fe39dcb7a" alt="Chrome"
Released January 29th —Release Notes (video)
class Counter {
_value = 0; // <-- public field
get value() {
return this._value;
}
increment() {
this._value++;
}
}
Chrome 72
data:image/s3,"s3://crabby-images/ba7dd/ba7dd48ccc5a4551f9fc69c4077e484fe39dcb7a" alt="Chrome"
NOTE: Private class fields "in the works"
class Counter {
#value = 0; // <-- *private* field
get value() {
return this.#value;
}
increment() {
this.#value++;
}
}
Chrome 72
data:image/s3,"s3://crabby-images/ba7dd/ba7dd48ccc5a4551f9fc69c4077e484fe39dcb7a" alt="Chrome"
- Reference implementation of the new spec
- Fixes Chrome bugs related to setTimeout, postMessage, etc.
console.log(navigator.userActivation)
UserActivation {
hasBeenActive: true
isActive: false
}
Chrome 72
data:image/s3,"s3://crabby-images/ba7dd/ba7dd48ccc5a4551f9fc69c4077e484fe39dcb7a" alt="Chrome"
- Simple internationalization of list data
- No need to bundle the Unicode CLDR in JavaScript
const lf = new Intl.ListFormat('en', { type: 'disjunction' });
lf.format(['Frank', 'Christine', 'Flora']);
// 'Frank, Christine, or Flora'
const lf2 = new Intl.ListFormat('zh');
lf2.format(['永鋒', '新宇', '芳遠', '澤遠']);
// '永鋒、新宇、芳遠和澤遠'
Chrome 72
data:image/s3,"s3://crabby-images/ba7dd/ba7dd48ccc5a4551f9fc69c4077e484fe39dcb7a" alt="Chrome"
- See first meaningful paint (FMP), DOMContentLoaded and more
data:image/s3,"s3://crabby-images/7be92/7be926a61f2f5ccb882dd97c5edcff5910169818" alt="Chrome performance metrics"
Chrome 72
data:image/s3,"s3://crabby-images/ba7dd/ba7dd48ccc5a4551f9fc69c4077e484fe39dcb7a" alt="Chrome"
- Enabled Trusted Web App support (app-embedded Chrome)
- Can be released via Google Play
- Sort of like inverse PWAs
Firefox 65
data:image/s3,"s3://crabby-images/6ac45/6ac457fbbd45d6ab50be6cf27448fd45f6e0b1fa" alt="Firefox"
Firefox 65
data:image/s3,"s3://crabby-images/6ac45/6ac457fbbd45d6ab50be6cf27448fd45f6e0b1fa" alt="Firefox"
fetch('https://someExpensiveResource')
.then(response => {
const reader = response.body.getReader();
// read each chunk and do something
})
Firefox 65
data:image/s3,"s3://crabby-images/6ac45/6ac457fbbd45d6ab50be6cf27448fd45f6e0b1fa" alt="Firefox"
- Collapsed framework stack traces
- Pause on XHR/Fetch breakpoints
Edge 18
data:image/s3,"s3://crabby-images/ad308/ad3081e44a26f932f9ef13e922e580e58fc25ca6" alt="Edge"
Switching to Chromium/V8 !!
Bonus: IE
data:image/s3,"s3://crabby-images/b32bf/b32bfd2dfea4d15f4bc48a4be349e81b680b856b" alt="IE"
Remember IE?
Enough is enough... Internet Explorer is a compatibility solution.
—Chris Jackson, Microsoft Cybersecurity Lead
Languages, Libraries &
Frameworks
Homebrew 2.0
data:image/s3,"s3://crabby-images/b5270/b5270fecd099245f9b10d2f4b6a3afc55c41eb5c" alt="Homebrew"
The missing package manager for macOS
Released February 2
- Now supports Linux and Windows 10!
- Automatic brew cleanup
- Improved option parsing, performance, linking and more
- Dropped OSX Mountain Lion (10.8) and below
Vue 2.6
data:image/s3,"s3://crabby-images/32b35/32b359f9a4d52af792beb7b0bd56c8981efeb23c" alt="Vue"
Released February 4
- New slots syntax and perf improvements
- Async error handling
- Server-side data pre-fetching
- And more!
React 16.8
data:image/s3,"s3://crabby-images/d46b9/d46b97db8c74a083d0441ee42f93e89042efd329" alt="React"
Released February 6
- "The one with hooks"
- Hooks: functions that let you “hook into” state and lifecycle events
- Basically, composable behavior reuse
- Backwards-compatible
HTML5 Boilerplate 7.0
data:image/s3,"s3://crabby-images/c38b6/c38b6009115f456b84ff8f2bafd95bff7f40ef71" alt="HTML5 Boilerplate"
The web’s most popular front-end template
Released February 8
- Dropped IE 9/10 support
- Documentation revamp
- Improved Webmanifest
- Other smaller improvements
Next.js 8.0
data:image/s3,"s3://crabby-images/6e9b2/6e9b26e7c62c0418c9d32b0f74f06ca2d4a94e9d" alt="Next.js"
Server-side React framework for apps, sites and more
Released February 11
Bootstrap 4.3
data:image/s3,"s3://crabby-images/d5739/d5739857798f8699598faab6bece6cf851790a07" alt="Bootstrap"
Server-side React framework for apps, sites and more
Released February 11
- New project to automate responsive font sizes
- Other mostly small improvements
- Moving toward v5:
- Switching docs from Jekyll to Hugo
- Dropping jQuery for vanilla JS
Don't Use "Do Not Track"
- Did you know there is a web standard for it?
- Most browsers support it, but most sites ignore it
- Safari 12.1 quietly removed it:
- They call it an "expired standard"
- It's a potential user fingerprinting variable
Facebook Sponsors LetsEncrypt
- 3-year renewal announced February 12th
- Platinum sponsorship == $300k / year!
- FB reports that 38% of HTTPS domains they see use LetsEncrypt
- Everyone should use it!
Galaxy Fold
- Launches April 26th for $1,980
- 4.6-inch phone → 7.3-inch tablet
- Rated for 200k folds
data:image/s3,"s3://crabby-images/efddb/efddb65f63d7fca722bf00246d2acbf1dfbc6430" alt="Galaxy Fold"
.dev Domains Available
Announced February 19
- Owned by Google (along with .app, .page and others)
- All .dev domains require HTTPS
- Might be a little pricey at the moment
Pure CSS Still Life
data:image/s3,"s3://crabby-images/913aa/913aa88de1d8c3e8c6496a635935972be9e19c37" alt="CSS Still Life"
NationalPark Typeface
A typeface designed to mimic the National Park Service signs that are carved using a router bit
- It's open source and comes in four weights
- Designed from physical park sign imprints
data:image/s3,"s3://crabby-images/91102/91102dceb713b22e9b999f11d49eaa699614b752" alt="BEW"
And now for something completely different...
The Periodic Table of AWS
data:image/s3,"s3://crabby-images/fa9b9/fa9b9ac306c58e9961ba0a19c3b2dc271a59b9d4" alt="Periodic AWS"
Animated Emoji URLs
Animate graphical unicode chars in the url bar (examples)
var f = ['🌑', '🌒', '🌓', '🌔', '🌝', '🌖', '🌗', '🌘'];
function loop() {
location.hash = f[Math.floor((Date.now()/100)%f.length)];
setTimeout(loop, 50);
}
loop();
Thanks!
←→ /
#