- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图通过阅读原始规范来理解 ES6 中新的标准化 block 级函数。我粗浅的理解是:
但是,由于这些语义的一部分被指定为“可选”并且仅对 Web 浏览器是强制的 ( Annex B ),这一事实使情况变得更加复杂。所以我想填写下表:
| Visible outside of block? | Hoisted? Up to which point? | "TDZ"? |------------------------------------------------------------------------------------------------------------------------| Non-strict mode, no "web extensions" | | | || Strict mode, no "web extensions" | | | || Non strict mode, with "web extensions | | | || Strict mode, with "web extensions" | | | |
Also it is unclear to me what "strict mode" means in this context. This distinction seems to be introduced in Annex B3.3, as part of some additional steps for the runtime execution of a function declaration:
1. If strict is false, then
...
但是,据我所知,strict
指的是函数对象的[[Strict]]
内部槽。这是否意味着:
// Non-strict surrounding code
{
function foo() {"use strict";}
}
上表中应该被视为“严格模式”吗?然而,这与我最初的直觉相矛盾。
请记住,我最感兴趣的是 ES6 规范本身,无论实际实现的不一致如何。
最佳答案
As far as I can see,
strict
refers to the[[Strict]]
internal slot of the function object.
没有。是的。它确实指的是函数 ( or script ) 的严格性,其中包含函数声明的 block 出现在其中。不考虑要声明(或不声明)的函数的严格性。
“网络扩展”仅适用于草率(非严格)代码,并且仅当函数语句的外观“正常”时 - 也就是说,例如,如果其名称不与正式的冲突参数或词法声明的变量。
请注意,如果没有网络兼容性语义,严格代码和草率代码之间没有区别。在纯 ES6 中, block 中的函数声明只有一种行为。
所以我们基本上有
| web-compat pure
-----------------+---------------------------------------------
strict mode ES6 | block hoisting block hoisting
sloppy mode ES6 | it's complicated ¹ block hoisting
strict mode ES5 | undefined behavior ² SyntaxError
sloppy mode ES5 | undefined behavior ³ SyntaxError
1:见下文。要求发出警告。
2:通常会抛出SyntaxError
3:ES5.1 §12中的注释谈到“实现之间存在重大且不可调和的差异”(例如 these )。建议发出警告。
现在,具有 Web 兼容性的 ES6 实现对于具有遗留语义的草率模式函数中的 block 中的函数声明有何行为?
首先,纯语义仍然适用。也就是说,函数声明被提升到词法 block 的顶部。
但是,还有一个 var
声明,它被提升到封闭函数的顶部。
当函数声明被求值时(在 block 中,就好像它像语句一样被满足),函数对象被分配给该函数范围的变量。
用代码可以更好地解释这一点:
function enclosing(…) {
…
{
…
function compat(…) { … }
…
}
…
}
工作原理与
相同function enclosing(…) {
var compat₀ = undefined; // function-scoped
…
{
let compat₁ = function compat(…) { … }; // block-scoped
…
compat₀ = compat₁;
…
}
…
}
是的,这有点令人困惑,有两个不同的绑定(bind)(用下标 0 和 1 表示)具有相同的名称。现在我可以简洁地回答您的问题:
Visible outside of block?
是的,就像var
。但是,还有一个仅在 block 内部可见的绑定(bind)。
Hoisted?
是的 - 两次。
Up to which point?
函数(但使用 undefined
初始化)和 block (使用函数对象初始化)。
"TDZ"?
不是指在引用时抛出异常的词法声明变量 (let
/const
/class
) 的临时死区,不。但在执行主体时遇到函数声明之前,函数作用域的变量是未定义
(尤其是在 block 之前),如果你尝试调用它,你也会得到一个异常.
仅供引用:在 ES6 中,上述行为仅针对函数作用域中的 block 指定。 Since ES7这同样适用于 eval
和全局范围内的 block 。
关于javascript - ES6 中 block 级函数的精确语义是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33304808/
在 settings.py LANGUAGE_CODE = 'es-mx'或 LANGUAGE_CODE = 'es-ar'不起作用,但是 LANGUAGE_CODE = 'es'或 LANGUAGE
我想知道OpenGL ES 2.0和OpenGL ES 3.0之间有什么区别。 OpenGL ES 3.0的主要优点是什么? 最佳答案 总体而言,这些变化通过更大的缓冲区、更多的格式、更多的统一等提高
这是我为此端点使用 Postman localhost:9201/response_v2_862875ee3a88a6d09c95bdbda029ce2b/_search 的请求正文 { "_sour
OpenGL ES 2.0 没有 ES 1.0 那样的 GL_POINT_SMOOTH 定义。这意味着我用来绘制圆圈的代码不再有效: glEnable(GL_POINT_SMOOTH); glPoin
我尝试编译这个着色器: varying vec2 TexCoords; varying vec4 color; uniform sampler2D text; uniform vec3 textCol
我是 OpenGL ES 的新手,我使用的是 OpenGL ES 2.0 版本。我可以在片段着色器中使用按位操作(右移、左移)吗? 最佳答案 OpenGL ES 2.0 没有按位运算符。 ES 3.0
有没有办法只用线画一个三角形? 我认为GL_TRIANGLES选项可使三角形充满颜色。 最佳答案 使用glPolygonMode(face, model)设置填充模式: glPolygonMode(G
我想用一个包含 yuv 数据的采样器在 opengl es 着色器中将 yuv 转换为 rgb。我的代码如下: 1)我将 yuv 数据发送到纹理: GLES20.glTexImage2D(GLES20
我正在使用这样的域: http://www.domain.com/es/blabla.html 我想更改 .es 的/es 部分并将 URLS 转换为类似以下内容: http://www.domain
有谁知道OpenGL ES是否支持GL_TEXTURE_RECTANGLE?我计划将它用于 2D 图形以支持非二次幂图像。我当前的实现使用 alpha=0 填充的 POT 纹理,对于拉伸(stretc
我需要在具有 PowerVR SGX 硬件的 ARM 设备上实现离屏纹理渲染。 一切都完成了(使用了像素缓冲区和 OpenGL ES 2.0 API)。唯一 Unresolved 问题是速度很慢glR
这是一个奇怪的事情。我有一个片段着色器,据我所知只能返回黑色或红色,但它将像素渲染为白色。如果我删除一根特定的线,它会返回我期望的颜色。它适用于 WebGL,但不适用于 Raspberry Pi 上的
我正在考虑将一些 OpenGL 代码移植到 OpenGL ES 并且想知道这段代码到底做了什么: glPushClientAttrib(GL_CLIENT_VERTEX_ARRAY_BIT) 因为 g
我正在考虑将一些 OpenGL 代码移植到 OpenGL ES 并且想知道这段代码到底做了什么: glPushClientAttrib(GL_CLIENT_VERTEX_ARRAY_BIT) 因为 g
GLSL ES最多可以编译多少个程序?所以假设我创建了 100 个片段着色器,每个都有不同的效果。所以在运行时我编译所有这些并动态地我用 glUseProgram 交换它们。我假设每次我编译一个新的
我正在尝试使用顶点缓冲区对象来绘制圆,并在 iPhone 上的 OpenGL ES 2.0 中启用 GL_POINT_SMOOTH 来绘制点。 我使用以下 ES 1.0 渲染代码在 iPhone 4
为什么在 OpenGL ES 1.x 中缩放(均匀)对象会导致对象变轻? 更有意义的是它会更暗,因为法线被缩小是否也会使对象更暗?但由于某种原因,物体变轻了。当我放大时,对象变得更暗。在我看来,这应该
我正在尝试通过移植 some code 在 iOS 上的 OpenGL ES 2.0 中获得一些阴影效果。来自标准 GL。部分示例涉及将深度缓冲区复制到纹理: glBindTexture(GL_TEX
所以我正在使用 2D 骨骼动画系统。 有 X 个骨骼,每个骨骼至少有 1 个部分(一个四边形,两个三角形)。平均而言,我可能有 20 块骨头和 30 个部分。大多数骨骼都依赖于父骨骼,骨骼会每帧移动。
我在使用 ES 着色器时遇到了一些晦涩难懂的问题,而且我现在几乎没有想法了。 这是一些代码: .. precision mediump float; .. #define STEP (1f/6f) 5
我是一名优秀的程序员,十分优秀!