不成熟的标准化
网站建设 2023-01-28 21:38www.1681989.com免费网站
原文地址http://yuiblog./blog/2008/08/14/premature-standardization/
The web is made of open standards. This was a significant factor the web’s displacement of proprietary application platforms. Openness is hugely attractive, so much so that the web domates over petitors with better technologies. The difficult tradeoff that es with a standards-based approach is that it is difficult to novate. As a result, the basic technologies of the browser have been stalled for a decade. What novation we’ve enjoyed, such as the Ajax revolution, has e by mg all of the latent, aidental potential of the existg standards. That potential has been used up.
互联网是由开放的标准组成的。这对互联网代替私有的应用平台是一个重要的因素。开放是非常有吸引力的,也正因为如此互联网凭借更好的技术控制着其他的竞争对手。当基于标准的方法来临时,无疑创新会变得越来越困难。结果是,浏览器最基本的技术停滞发展了一段很长的时间。一些让我们欣喜的创新,如AJAX革命等,是一种在现有标准上的再发掘的潜能。这种潜能已经几近枯竭。
If we are to go forward, we must repair the standards. This is somethg that must be done with great care. A revision to a standard is an act of violence, just like any surgical procedure. It should only be undertaken when the likely benefit far exceeds the cost and the pa and the risk. The web is particularly troublesome because it did not anticipate the management of software updates, which is why IE5, an ancient browser, still has more users than Safari and Opera bed. Changes to the standard can put developers a very difficult position because the benefits to users of some browsers bee the seeds of failure for the users of others. Developers must manage this gulf, and it is not easy. Developers are not well served by new standards that make their jobs even harder.
如果我们想继续往前走更远,我们必须修正标准。这是一项必须非常小心的事情。标准的修订是一种暴力行为,如同外科手术一样。只有在标准带来的好处远远高于它本身的耗费及缺点时,标准才能真正被使用。互联网并没有预先的软件升级管理,这使得它成为了一个非常复杂的环境,就比如IE5,一个非常非常古老的浏览器,其用户份额却比Safari和Opera加起来还要更多。正因为如此,标准的改变将使开发者陷入一个非常困难的环境,很多对于某些浏览器的优点却可能变成其他浏览器潜在的错误。开发者必须管理并减小这些差别,但这却是不容易的。,开发者未能更好的适应使用新标准也增加了他们工作的难度。
I thk it is structive to look at two approaches to managg novation with a standards based system, one that I view as a suess, and the other not so much. JavaScript was a promisg but half-baked language that was irresponsibly rushed to market and then irresponsibly cast to a standard. That standard is called ECMAScript to avoid a trademark dispute. That standard was last revised 1999.
我觉得,把基于标准的系统和并不十分标准的系统放在一起比较并产生革新是非常有益的。JavaScript是一个非常有希望的语言,但它的自身也非常不成熟,它被过快的不负责任地扔入了浏览器市场,又被不负责任地扔入了标准的圈子里。为了避免潜在的版权纠纷,这项标准被称为ECMAScript。它更新的时间是1999年。
It is clear that the language needs to be updated, but TC39 (the mittee that is responsible for draftg a new standard) could not reach consensus on how to do it, so it split to two groups, each producg its own proposal. This was a good thg that petition is healthy, and I believe that petition spired improvements to both proposals. This was also a bad thg because no standards anization can adopt two proposal for the same standard. Without consensus, both proposals must fail.
非常显而易见的,这门语言需要更新升级了。TC39在如何更新的问题上,却不能达到一致。所以他们分成了两个小组,分别实现各自的目标。这样的健康的竞争是非常有帮助的,我也相信竞争会改善两组各自的目标。 ,这也是个不好的事情,因为没有一个标准组织会接受一项标准拥有两个不同的提议。如果不能达成一致,这两个提议都将会失败。
On one side there was the proposal called ES4. It was unfortunate that it adopted that name because it strongly suggested that it was dested to be the Fourth Edition of ECMAScript, a fate that was not certa. The project was very open to new ideas and features, adoptg a porkbarrel attitude that was almost Congressional its expansiveness. Lots of good ideas were cluded without an adequate analysis of the language as a whole system. As a result, many overlappg features were adopted which would have significantly creased the plexity of the language.
其中一项提议被称为ES4。这个名称的使用很不幸运,因为它强烈的暗示了它一定会是ECMAScript的第四版,它并不一定会是。该项目对于新思想新特征非常的开放,并采纳了许多看法,尽管这些思想并没有基于这门语言系统进行充分的分析。结果,许多复杂的特征被采用,并最终提升了整个语言的复杂性。
ES4 was so large and so novative that there were doubts about whether it could be suessfully specified and implemented. More worrisome, there was no experience with the language itself. Would the teraction of features cause untended problems as we saw ES1 and ES3? The schedule for ES4 required that the standard be put place and adopted by the browser makers before that question could be answered. This is a problem because once a bug is serted to a standard, it can be extremely difficult to remove it. All of the features, considered dividually, were attractive. But taken as a whole, the language was a mess.
ES4非常的庞大,也引入了许多新思想,这不禁令人们担心它会不会被成功的接受和使用。更令人不安的是,对于语言的本身,并没有任何使用经验。那些极富吸引力的新特性会不会如ES1和ES3一样产生许多潜在的问题?ES4的制定安排要求这项标准必须被浏览器开发者接受并植入浏览器后才能回答刚才的问题。这会是一个很大的问题,当一个小bug错误的加入了标准,到时候想要去除掉它就会非常的困难了。单独考虑ES4所有的新特性,都是非常有吸引力的。全部放到一起,语言非常的混乱。
On the other side was a proposal called ES3.1. Its name dicated a less ambitious proposal, beg a smaller crement over the current Third Edition. This project was tended to repair as many of the problems with the language as possible while mimizg the pa of disruption. New syntax was considered only when it was already implemented and proven at least three of the four major browsers. Feature selection tended to favor necessary improvements over desirable improvements.
另一项提议被称为ES3.1。它的名字暗示它相比于现在的ES3只有较少的变革。这个项目的目标是修复语言中存在的诸多错误。新的句法只有在至少三至四个主流浏览器植入并测试过之后才会被考虑加入。他们更多的选择必须的特性,而不是可拥有的特性。
ES3.1 was more mimal approach. The set of feature teractions was much smaller and much easier to reason about. ES3.1 is likely to plete its specification and will be the candidate for the Fourth Edition.
ES3.1更容易接受。新特性的吸引力会较小,也更容易实现。ES3.1也可能完成它的文档,从而成为ES真正第四版的候选。
ES4 had a large head start (by as much as seven years by some estimates), but was unable to meet its deadles. Ultimately, the project fell apart when some of the key members left.
ES4的制定起步很早(估计至少7年之前),我们看不到它到底什么时候能结束。最终,由于核心成员的离去,这项工程被搁浅。
Some of the features that were ES4 were reasonable, so a new project, called Harmony, is startg which will look at adaptg the best of ES4 on of ES3.1. The suess of this project will depend on the ability of TC39 to do a better job of managg the tradeoffs between novation and stability, and adoptg a disciple for managg plexity. Simplicity should be highly valued a standard. Simplicity cannot be added. Instead, plexity must be removed.
现在,由ES4引入的一些合理的新特性,重新成为了一项新项目,被称为Harmony。这个项目的成功与否取决于TC39权衡创新与稳定二者的能力,以及对复杂度的管理上。在某种程度上,简约应受到足够的重视,而不应被矫饰。所以,一些冗余必须被剔除。
It turns out that standard bodies are not good places to novate. That’s what laboratories and startups are for. Standards must be drafted by consensus. Standards must be free of controversy. If a feature is too murky to produce a consensus, then it should not be a candidate for standardization. It is for a good reason that “design by mittee” is a pejorative. Standards bodies should not be the busess of design. They should stick to careful specification, which is important and difficult work.
现在看来标准的主体并不是一个创新的好地方。这也正是实验室存在的目的。标准必须经过一致的协商,也必须有充分的辩论。如果一个特性很难达成一致,那么它应 该从标准草案中去除。标准的主体不能在有商业目的的情况下设计。它们必须坚持谨慎的设计,这是一个相当困难的工作。
I see similar stories HTML5. The early work of WHATWG documentg the undocumented behavior of HTML was brilliant. It went off the rails when people started to just make new stuff up. There is way too much controversy HTML5. I would like to see a plete reset with a stronger set of design rules. Thgs can be much worse than the way thgs currently are. Havg smart people with good tentions is necessary but not sufficient for makg good standards.
我也在HTML5里面看见了很类似的情况。WHATWG的早期对于文档化HTML中没有文档的特性的工作是非常棒的。当人们开始只关注创造新东西时,它们开始偏离轨道。在HTML5中存在太多的争议。事情可能会比现在存在的更糟糕。也许,让一些有目的的聪明人制定好的标准是必须却又不够的。
延伸阅读
http://almaer./blog/javascript-2-a-perl-6-disaster-that-matters-so-much-more-but-wait
http://ajaxian./archives/ecmascript-harmony-g-together-after-oslo
http://ejohn./blog/ecmascript-harmony/