微软Web应用的发展过程

简介:

近日,微软Edge团队发表了一篇博文,介绍Web应用在微软的发展过程。本文将择要介绍Web应用如何从一个“大型的文档空间(a large universe of documents)”演化成了如今的通用应用程序平台。

在Windows上,最早的Web应用形态可能是IE9引入的“钉选网站(Pinned Sites)”。所谓的钉选网站是指站点可以固定到Windows 7任务栏,并且可以使用自定义的图标。后来,该特性提供了一个类似清单文件的东西,告诉平台该站点可以“像一个应用”那样运行,并提供了如何集成到主屏幕/开始菜单的详细信息。而且,当W3C推出了相应的清单文件标准时,他们欣然采用了新的标准。

Web应用的真正出现是在Windows 8上。有段时间,Windows 8去掉了开始菜单,其初衷是为了让Web成为Windows上的一等公民,让Web真正可以在浏览器之外运行,而且不需要原生代码。从技术上讲,浏览器进程甚至都没有参与Web应用在Windows上的运行,减少了内存/CPU的工作负载,每个Web应用都有自己的缓存。Web应用完全整合进了Windows的应用模型,让用户可以管理通知,离线或在后台运行应用,甚至像原生应用那样卸载它们。开发人员可以更深入地集成平台,使用一些Web平台原本不具备的原生功能。微软创建了类似chrome.* namespace的Windows Runtime JS APIs。自此,WinRT孕育了Pointer Events、Web Notifications、Push API、Web Payments等API,使Web应用可以更快地用上原生功能。

为了将Web应用打包,创建离线优先的用户体验,让其直接与原生应用进行竞争,Windows 10提供了“托管Web应用(HWA)”。它提供了一个简单的清单文件,指向Web应用的URL。HWA应用可以像打包的应用那样独立于浏览器运行,但实时从服务器加载,让用户可以免于冗长的应用商店提交过程。

Progressive Web App(PWA)是HWA的一个自然扩展。本质上,PWA是HWA加上如下已经在开发的标准:

Fetch(以预览构建版形式提供) Service Worker(开发中) Cache API(开发中) Push API(开发中)

在许多方面,现有的PWA实现(Android上的Chrome/Opera/Samsung)仍然把Web应用作为二等公民。它们有主屏幕快捷方式,但不会出现在应用列表中,也不会报告存储/数据/电池的使用情况,无法配置、管理、卸载等。微软的目标更进一步,他们希望解决这些问题,提供全功能的应用。

目前,正在进行的工作有以下两项:

实现上述标准; 在Windows应用商店中构建对W3C Web应用清单的支持。

第一项工作让PWA可以通过Chrome/Opera运行在Android平台上,或者通过EdgeHTML运行在Windows平台上。第二项工作让PWA可以出现在应用商店的列表中,并在浏览器页签之外运行。如何在应用商店中列出PWA,用户如何在Windows上安装PWA,这是微软正在努力解决的两个实际问题。感兴趣的读者可以关注Edge开发的官方Twitter。





====================================分割线================================


本文转自d1net(转载)

目录
相关文章
|
5天前
|
缓存 前端开发 安全
GraphQL在现代Web应用中的应用与优势
GraphQL是一种现代的API查询语言,它在现代Web应用中得到了广泛的应用,因为它提供了一种高效、灵活且强大的方式来获取数据
14 0
|
8天前
|
前端开发 数据库 开发者
探索现代Web应用的性能优化策略
【5月更文挑战第20天】 在当今的网络环境中,用户对Web应用的性能要求日益增长。一个高性能的Web应用能够带来更好的用户体验,提高转化率和用户留存率。本文将深入探讨现代Web应用性能优化的关键策略,包括前端优化技巧、后端性能提升以及数据库查询优化等方面。通过实践案例和性能测试数据,我们揭示了这些策略对于提升Web应用性能的实际效果,为开发者提供了一套全面的性能优化工具箱。
|
8天前
|
缓存 API 数据库
构建高效Python Web应用:Flask框架与RESTful API设计原则
【5月更文挑战第20天】 在现代Web开发中,构建一个轻量级且高效的后端服务至关重要。本文将深入探讨如何使用Python的Flask框架结合RESTful API设计原则来创建可扩展和易于维护的Web应用程序。我们将通过分析Flask的核心特性,以及如何利用它来实现资源的合理划分、接口的版本控制和请求处理优化等,来指导读者打造高性能的API服务。文中不仅提供了理论指导,还包括了实践案例,旨在帮助开发者提升开发效率,并增强应用的稳定性和用户体验。
|
8天前
|
前端开发 Java Go
从前端到后端:构建现代化Web应用的技术演进
本文探讨了从前端到后端的技术演进,介绍了前端、后端以及多种编程语言,如Java、Python、C、PHP和Go,以及数据库在构建现代化Web应用中的应用。通过深入剖析各个技术领域的发展和应用,读者将对构建高效、可扩展、安全的Web应用有更深入的理解。
|
10天前
|
缓存 监控 安全
Django框架在大型Web应用中的架构设计与实战
【5月更文挑战第18天】Django框架在构建大型Web应用中扮演重要角色,采用分层架构(数据、业务逻辑、表示层)和多应用组织模式,结合缓存策略(如Memcached、Redis)提升性能。通过异步处理、分布式部署提高响应速度和扩展性。关注数据分区、安全设计及监控日志,确保系统高效、稳定。Django为复杂业务提供坚实基础,助力打造卓越Web系统。
40 7
|
10天前
|
开发框架 中间件 数据库
Django 框架入门全攻略:轻松构建 Web 应用
【5月更文挑战第18天】本文是 Django 入门教程,介绍了如何使用 Django 构建 Web 应用。内容包括安装、项目与应用创建、模型定义、数据库迁移、视图编写、路由配置、模板系统、表单处理和中间件的使用。通过实例展示了 Django 基本流程,帮助初学者快速上手。Django 提供高效工具,便于开发者聚焦业务逻辑,轻松构建功能丰富的 Web 应用。
34 5
|
10天前
|
存储 缓存 API
Flask 框架在大型 Web 应用中的使用与挑战
【5月更文挑战第18天】Flask框架适用于快速开发轻量级Web应用,但用于大型应用时需应对性能、代码管理和团队协作的挑战。通过集成扩展处理复杂需求,使用蓝图组织代码,以及引入缓存优化性能,结合明确的代码规范和开发流程,可有效应对挑战,构建高效稳定的应用。
41 5
|
10天前
|
数据库连接 Python
Flask 框架入门与实践:构建你的第一个 Web 应用
【5月更文挑战第18天】本文介绍了使用 Flask 框架构建第一个 Web 应用的步骤。首先通过 `pip install Flask` 安装框架,然后编写基本的 Python 代码创建应用,包括定义路由和响应。示例展示如何显示 "Hello, World!",并扩展到显示用户信息的功能。利用模板(如 `index.html`)可使页面更丰富。随着学习深入,可以利用 Flask 的更多特性,如表单处理和数据库连接,来构建更复杂的 Web 应用。本文旨在激发读者对 Flask 和 Web 开发的兴趣,鼓励不断探索和实践。
47 7
|
11天前
|
前端开发 Java Go
从前端到后端:构建现代化Web应用的技术实践
本文将介绍如何通过前端和后端技术相结合,构建现代化Web应用的技术实践。我们将探讨前端开发、后端架构以及多种编程语言(如Java、Python、C、PHP、Go)在构建高效、可扩展的Web应用中的应用。
|
12天前
|
JavaScript 前端开发 API
Vue中的组件:构建现代Web应用的基石
Vue中的组件:构建现代Web应用的基石