一、语法
1 | background-image: linear-gradient([<angle>|<side-or-corner>,]?<color-stop>[,<color-stop>]+); |
[]在正则中表示一个字符类,这里,你可以理解为一个小单元。
|表示候选。也就是“或者”的意思,要么前面的,要么就后面的。
?为量词,表示0个或1个。
+也是量词,表示1个或者更多个。因此,终止颜色是不可缺少的。
<>中的是关键字,主要是让开发人员知道这里应该放些什么内容。
1 | var dsHandler = function(evt) { |
1 | object-fit : css property specifies how the contents of a replaced element should be fitted to the box established by its used height and width. |
这里的object实际上指的是replaced element 。
其内容不受CSS视觉格式化模型控制的元素。
1 | navigator.mediaDevices.getUserMedia(constraints) |
MediaDevices.getUserMedia()会提示用户给予使用媒体输入的许可。它返回一个 Promise 对象,成功后会resolve回调一个 MediaStream 对象。若用户拒绝了使用权限,或者需要的媒体源不可用,promise会reject回调一个 PermissionDeniedError 或者 NotFoundError 。
以下同时请求不带任何参数的音频和视频:
1 | { |
当由于隐私保护的原因,无法访问用户的摄像头和麦克风信息时,应用可以使用额外的constraints参数请求它所需要或者想要的摄像头和麦克风能力。下面演示了应用想要使用1280x720的摄像头分辨率:
1 | { |
浏览器会试着满足这个请求参数,但是如果无法准确满足此请求中参数要求或者用户选择覆盖了请求中的参数时,有可能返回其它的分辨率。
1 | //label: statement; |
1 | stringObject.replace(regexp/substr,replacement); |
在 stringObject 中查找与 regexp 相匹配的子字符串,然后用 replacement 来替换这些子串。如果 regexp 具有全局标志 g,那么 replace() 方法将替换所有匹配的子串。否则,它只替换第一个匹配子串。
replacement 可以是字符串,也可以是函数。如果它是字符串,那么每个匹配都将由字符串替换。
replacement 中的 $ 字符具有特定的含义。如下表所示,它说明从模式匹配得到的字符串将用于替换。
字符 | 替换文本 |
---|---|
$1、$2、…、$99 | 与 regexp 中的第 1 到第 99 个子表达式相匹配的文本。 |
$& | 与 regexp 相匹配的子串。 |
$` | 位于匹配子串左侧的文本。 |
$’ | 位于匹配子串右侧的文本。 |
$$ | 直接量符号。 |
1 | //检测字符串 |
这个 API 看着没什么毛病,能检测常用的一些数据。但是有以下两个问题。