type="text/ecmascript" vs type="text/javascript"
The current version of the HTML standard (last updated 16 July 2019) says that the language type specified with the type
attribute of the <script>
tag falls back to text/javascript
if ommitted.
Also that specification specifies that:
Servers should use text/javascript for JavaScript resources. Servers should not use other JavaScript MIME types for JavaScript resources, and must not use non-JavaScript MIME types.
TL;DR Just omit the type
tag, if you don't care about old browsers.
ECMAScript is a language specification standardized by ECMA International as ECMA-262 and ISO/IEC 16262. JavaScript is a programming language that implements this specification. ECMAScript exists in several editions. The latest edition is the 6th (in 2016), but most JavaScript implementations are only 5th edition compliant so far.
Besides ECMAScript common JavaScript implementations usually add more functionality, which might be standardized by other institutions (like the W3C) or might be proprietary (aka "browser-specific") features of the specific implementation. So you could say, that ECMAScript represents a subset of JavaScript.
However, the MIME types for JavaScript code are defined in the RFC 4329 document, which states that text/javascript
and text/ecmascript
are both obsolete and should be replaced by application/javascript
and application/ecmascript
:
Use of the "text" top-level type for this kind of content is known to be problematic. This document thus defines text/javascript and text/ ecmascript but marks them as "obsolete".
The RFC defines stricter processing rules for the application/ecmascript
than for application/javascript
, but this refers to the handling of MIME-type parameters and the character encoding and not to the interpretation of the code itself:
In the cited case, implementations of the types text/javascript, text/ecmascript, and application/javascript SHOULD and implementations of the type application/ecmascript MUST implement the requirements defined in this section: [...]
For the application/ecmascript media type, implementations MUST NOT process content labeled with a "version" parameter as if no such parameter had been specified; [...]
The following error processing behavior is RECOMMENDED for the media types text/javascript, text/ecmascript, and application/javascript, and REQUIRED for the media type application/ecmascript.
Apart from the RFCs, there is also the HTML5-Standard by the W3C: Older versions of it say, that the default value for an empty type
attribute is application/javascript
, but newer versions don't mention any specific MIME-type anymore. Instead they define any script
tag with no type or a MIME-type as a so-called "classic script":
Omitting the attribute, setting it to the empty string, or setting it to a JavaScript MIME type essence match, means that the script is a classic script, to be interpreted according to the JavaScript Script top-level production. Classic scripts are affected by the async and defer attributes, but only when the src attribute is set. Authors should omit the type attribute instead of redundantly setting it.
In general I would omit the type
attribute (as recommended by the HTML5-Standard) or use type="text/javascript"
, if you have to support older browsers. A HTTP-Server should serve JavaScript code as application/javascript
.