写点什么

浏览器应用的下一阶段会需要什么?

  • 2007-11-30
  • 本文字数:1543 字

    阅读完需:约 5 分钟

在波士顿 Ajax 体验大会的主题展示上,Alex Russell 和 Joe Walker 提出了这样一个问题“什么可以将浏览器应用开发带到新的层次上?”。

现阶段 Ajax 工具套件的竞争以 IE 的胜出而告终,所有的浏览器供应商都进入了一个稳定期。浏览器特性的停滞不前,表明我们需要开发新的库以提供新的应用特性。现有的库已经为突破浏览器的功能提供了良好的解决方案,同时也为开发人员提供了一个浏览器兼容层。

为了跨越前期高点,Alex 和 Joe 就功能、可靠性、信任和动力几个方面需要解决的问题提出了一些想法

1. 特性

尽管需要新的特性以提供更好的用户体验,但是我们需要小心从事,很重要的一点就是任何新特性都不应该破坏已有特性,并且该新特性应该被所有的供应商所支持。

实际上,新特性并不是由浏览器提供的,而是由 Ajax 库来提供的,因而,我们不得不面对的一个重要的问题:“这些库到底能走多远?”

Ajax 库正通过 Comet、3D(VML/SVG/Canvas)、存储以及下载等功能来逐步摆脱限制。

只有通过使用大量 Hack 技术才能确保 Ajax 库对现有 web 技术提供支持。

另一个将长期困绕新浏览器特性使用的问题源自浏览器本身的淘汰过程,即使新的特性已经被加入到了新一代 web 浏览器中,但当前浏览器的更新换代周期可能需要 5 年甚至更长时间来完成,这就要求 Ajax 工具承担更多的责任,帮助在不同时期浏览器间进行透明转换。

2. 可靠性

可靠性将成为新版 web 浏览器的一个重要特性, “内容不完整”胜于“抛出异常”,这早就不是什么新问题了,而 web 浏览器仍然需要像以前那样去处理格式不正确的内容,同样,处理技术也不只一种,就像现在支持的不同版本 HTML,CSS 和 JavaScript 一样,需要有新的版本和新的技术处理他们。

我们需要向生物学习,以提供既能应付错误,又能不断发展的浏览器。

3. 信任

什么地方会出错呢?开发者现在需要考虑很多方面,包含:

  • Web 蠕虫
  • 隐私入侵
  • 数据传输
  • 身份窃取
  • 浏览器安全
  • 如何构建信任

新一代的浏览器应该能帮助开发者构建安全可信任的应用,为了达到这个目标,我们应该开发出可靠的模式,这些模式需要满足以下两点:

  • 按照用户期望的方式去响应
  • 遵循最小惊讶原则

有很多行为都会削弱用户的信任 — 我们需要面对他们。来自 Joe 和 Alex 的对特性的建议可以帮助开发者:

  • 基于块的内容限制
  • 对 cookies 的跨站点请求伪造(Cross-Site Request Forgeries,即 CSRF)的预防
  • 沙箱(Sandboxing )
  • 构建关系的稳定模型(SMASH/XIP/etc)

无论我们是否喜欢,用户信任任何新技术都是需要时间的。

4. 动力

幸运的是,web 如今获得了巨大的推动力,已经成为当今应用交付的首选形式。对于 web 来说,开发者已经开发部署了大量的应用。

作为开发者,我们可以参与并影响标准的内容,以达到延续其动力和持续改进我们正在使用的技术的目的。

我们需要使标准充满生机,用户和社区的参与和推动下,标准的处理的过程也越来越透明化。

浏览器的供应商也在不断提供动力,但是并不存在什么规范可供他们按图索骥,他们正承担着风险,所以我们应该鼓励他们,尤其,当插件提供着一种打破本地局限的方式时,所有的 web 开发者都需要面对的一个问题是:“下一个版本的开发是继续凭藉浏览器本身,还是别的什么站在浏览器肩膀上的技术呢?”

作为结论,Alex 和 Joe 提出了另一个问题,这一次是反问:

随着 Ajax 工具箱和插件的使用,我们是否已经找到了一种解决方案使得 web 浏览器不需要更新换代呢?

查看英文原文 What is Needed for the Next Level of Browser Applications? - - - - - -

译者简介:张龙,同济大学软件工程硕士,现就职于理光软件研究所。主要从事文档工作流和办公自动化解决方案的研发工作。热衷于 Java 轻量级框架的研究,对敏捷方法很感兴趣。曾有若干年的 J2EE 培训讲师经历。参与 InfoQ 中文站内容建设,请邮件至 china-editorial@infoq.com

2007-11-30 02:59511
用户头像

发布了 88 篇内容, 共 274.0 次阅读, 收获喜欢 9 次。

关注

评论

发布
暂无评论
发现更多内容

golang 中 time 包使用教程之基础使用篇

Go学堂

golang 程序员 个人成长 time.Time 时间转换

前端js手写面试题汇总(一)

helloworld1024fd

JavaScript

自己手写一个redux

helloworld1024fd

JavaScript

React核心技术浅析

夏天的味道123

React

技术界中的虚拟机、容器和沙箱的关系

FinFish

容器 虚拟机 安全沙箱

主成分分析PCA与奇异值分解SVD-降维的实现方法

烧灯续昼2002

Python 机器学习 算法 sklearn 11月月更

熬夜整理的vue面试题

bb_xiaxia1998

Vue

Python进阶(四十)应用matplotlib绘图实战

No Silver Bullet

Python matplotlib 11月月更

面试官:能用JavaScript手写一个bind函数吗

helloworld1024fd

JavaScript

React-diff原理及应用

xiaofeng

React

读懂React原理之调和与Fiber

xiaofeng

React

最近面试被问到的vue题

bb_xiaxia1998

Vue

Vue的computed和watch的区别是什么?

bb_xiaxia1998

Vue

Python进阶(四十一)Python3解决“tuple parameter unpacking is not supported in python3”

No Silver Bullet

Python3 问题分析 11月月更

React源码解读之React Fiber

flyzz177

React

前端代码规范常见错误 二

默默的成长

前端 Vue 3 11月月更

new Vue的时候到底做了什么

bb_xiaxia1998

Vue

Python进阶(四十三)glob 文件路径查找

No Silver Bullet

Python 11月月更 glob 文件查找

虚拟机、沙箱和容器之间的区别

Onegun

容器 虚拟机 沙箱

React-Hook最佳实践

xiaofeng

React

前端代码规范常见错误 一

默默的成长

前端 Vue 3 11月月更

React源码解读之任务调度

flyzz177

React

「Go工具箱」推荐一个轻量级、语义化的时间处理库:carbon

Go学堂

golang 开源 程序员 carbon 日期时间转换

这可能是你需要的React实战技巧

夏天的味道123

React

浪潮信息工程师:谈一谈设备透传虚拟机启动慢背后的原因及其优化方法 | 第 51 期

OpenAnolis小助手

Linux 系统运维 内核 龙蜥大讲堂 浪潮

React源码解读之更新的创建

flyzz177

React

移动前端的安全管理方案

Onegun

前端 安全

通俗易懂的React事件系统工作原理

夏天的味道123

React

6个步骤强化 CI/CD 安全

SEAL安全

前端js手写面试题汇总(二)

helloworld1024fd

JavaScript

微博:公布热搜算法!

博文视点Broadview

浏览器应用的下一阶段会需要什么?_Java_Ian Roughley_InfoQ精选文章