What’s New in Safari and WebKit
What’s New in Safari and WebKit
WWDC 2018
Use WKWebView
- UIWebView deprecate
- Works on macOS and iOS
- Runs in a separate process from your app
Extending Safari: History
- 2010: Safari Extensions
- 2014: App Extensibility for macOS and iOS
- 2015: Content Blockers for macOS and iOS
- 2016: Safari App Extensions for macOS
Legacy Safari Extensions
- Safari 12 blocks support for
.safariextz
extension
outside of the Safari Extensions Gallary - New submissions to the Safari Extensions Gallery
will be accepted util the end of 2018 ⚠️ - Transition to a Safari App Extension or Content Blocker
Subresource Integrity
data:image/s3,"s3://crabby-images/09fbd/09fbd66e22d71c52e79ffbd7b3926d0950958142" alt=""
data:image/s3,"s3://crabby-images/b1f3f/b1f3f3847f86ca9ad51089ee9671552fb440e908" alt=""
Demo
The hash doesn’t match. So, Safari has blocked it from being loaded.
data:image/s3,"s3://crabby-images/0b2db/0b2db678cbaaa76dc6bc9e732e029485a67fe6a9" alt=""
Intelligent Tracking Prevention
Storage Access API ( new )
data:image/s3,"s3://crabby-images/db07d/db07d1506ef0f8c34846e72dbaf3d44e9c0adf4b" alt=""
data:image/s3,"s3://crabby-images/c0e9f/c0e9f54b506bfbe53e3235f504ff057a11db2c47" alt=""
AutoFill for Safari
data:image/s3,"s3://crabby-images/742ea/742eac5f7a2571cb8c37443bb41bb83ec17625ad" alt=""
data:image/s3,"s3://crabby-images/474ba/474baccd5122468867158b230edebea435f3c1b2" alt=""
Default Password Format ( new )
- 20 characters long
- Contain upper-case, digits, hyphen, and lower-case
- Use
passwordrules
attributes for custom password rules - Password rules validation tool
data:image/s3,"s3://crabby-images/484fb/484fb8bec289e6a089e5799773dbc60d4450134d" alt=""
Security Code AutoFill ( new )
data:image/s3,"s3://crabby-images/348fb/348fb0492384733c52b57c7ba8d1bc7e37897877" alt=""
Font Collections ( new )
Similar Unicode fonts downloaded more quickly
data:image/s3,"s3://crabby-images/6695c/6695c42a99c3e15409cfcfd81c8af53f0a968522" alt=""
font-display Descriptor ( new )
data:image/s3,"s3://crabby-images/cadcf/cadcfa0da27b135270f209393c82673afdddce52" alt=""
data:image/s3,"s3://crabby-images/d173c/d173c305cb658bd77621c53d847dd1b17a59420c" alt=""
Videos in Image Elements
data:image/s3,"s3://crabby-images/40f48/40f480ec6394827107a1f425d5570aefb6920377" alt=""
data:image/s3,"s3://crabby-images/02add/02adde711551a883ef354e90a9262337582684c7" alt=""
data:image/s3,"s3://crabby-images/47b7c/47b7cb7a28fa3e2f2aba9d4bd1e1b2dec2e827f1" alt=""
Demo
gif → mp4
data:image/s3,"s3://crabby-images/60014/600143b97f641fcee4e3ea2e4943bdcdc096a1ba" alt=""
Passive Event Listeners ( new )
- Enabled on
document
,window
, andbody
elements by default - Flag to always allow scrolling
- No interruptions
data:image/s3,"s3://crabby-images/2717b/2717b85b0fd3a2f1ef1e39f54c7d77fcfcac4a67" alt=""
data:image/s3,"s3://crabby-images/7b246/7b2467a7be77009993890640c7ab12a49dac3590" alt=""
Image Decoding ( new )
- Synchronous 😡
- Main thread is blocked
- User interactions prevents until all images are decoded - Asynchronous 😆
- On separate thread
- Parallel decoding operations
- User interactions aren’t blocked
- Default on 1st page load
- Markup: Add thedecoding
attribute to an element
- JavaScript: UseHTMLImageElement.decode()
data:image/s3,"s3://crabby-images/88489/88489dfc3fc183a6dc3f69d0ff16d9d4ce58015c" alt=""
data:image/s3,"s3://crabby-images/3a2d1/3a2d14b2133d8409029abc2fa7450a1887812558" alt=""
Demo
No flash. Smooth transition.
data:image/s3,"s3://crabby-images/7bb34/7bb349be562fc678e654626beef5b860ecf4de6c" alt=""
Beacon API
Asynchronous request on unload event
- Sends data on unload without waiting for a response
- Smooth browser navigation while waiting for response
- Ensure delivery of data while Safari is running
data:image/s3,"s3://crabby-images/f1801/f1801f9c7a14face80a5dfcdf42485a12ff23893" alt=""
Drag and Drop Improvements
- Directory uplaod
- Read and write support for MIME types ( HTML, plaintext, and URLs)
- iOS:
DataTransfer.getData
andDataTransfer.setData
Demo
data:image/s3,"s3://crabby-images/b4552/b455212ceabe0b53829a7f2258fe1add538c6a81" alt=""
data:image/s3,"s3://crabby-images/98085/9808539a6d816ef9b8a3e747ada0686d6f189025" alt=""
Payment Request API + Apple Pay ( new )
- Support for Apple Pay using Payment Request API
- Still need to support Apple Pay specifics
- Apple Pay JS features
- Granular error handling
- Cobranded card support
- Phonetic names
Demo
data:image/s3,"s3://crabby-images/ca291/ca2919105dd95f6e6afe1bcb81b40f01fe121a77" alt=""
data:image/s3,"s3://crabby-images/0572f/0572f27ca7a600b57c7fcc75b1546c41106f7e4f" alt=""
data:image/s3,"s3://crabby-images/1e879/1e879427fdae276336a0c120030092dfc138c541" alt=""
Service Worker API ( new )
- Great offline experience
- Cache interactions
- Intercept requests - Multiple tabs share 1 instance
- Persistent store of resources
Fullscreen API for iPad
CSS Environment Variables
data:image/s3,"s3://crabby-images/b90c4/b90c483ad4b2399025e698a239c60f05724b7768" alt=""
AR Quick Look + Safari
data:image/s3,"s3://crabby-images/be53f/be53f1f8b09634bd6b6054e22113288c6320db45" alt=""