Skip to content

Commit df33a14

Browse files
committed
Add notes.
1 parent 81f1306 commit df33a14

File tree

3 files changed

+62
-2
lines changed

3 files changed

+62
-2
lines changed

.gitignore

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -35,4 +35,4 @@ notes/*/*.md
3535
!notes/*/506.md
3636
!notes/*/508.md
3737
!notes/*/509.md
38-
!notes/*/603.md
38+
!notes/chapter-6/*.md

doc/index.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -64,7 +64,7 @@ issue: 17
6464
604| [32] 通过阴影来弱化背景|-|〃|-
6565
605| [33] 通过模糊来弱化背景|-|〃|-
6666
606| [34] 滚动提示|-|〃|-
67-
607| [35] 交互式的图片对比控件|-|〃|-
67+
607| [35] 交互式的图片对比控件|-|〃| [免费阅读](https://github.com/cssmagic/CSS-Secrets/issues/74)
6868
|
6969
**第七章** | **结构与布局**|| [购买后阅读 <sup>↗</sup>](http://www.ituring.com.cn/tupubarticle/9399)|
7070
701| [36] 自适应内部元素|-|〃|-

notes/chapter-6/607.md

Lines changed: 60 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,60 @@
1+
---
2+
title: "[注解] [607] 交互式的图片对比控件"
3+
issue: 74
4+
---
5+
6+
## 花絮与注解
7+
8+
#### 第 169 页 ‧ 第二个代码块
9+
10+
> ```js
11+
> range.oninput = function() {...}
12+
> ```
13+
14+
这一段在 JS 代码中,作者为简化代码,采用 `.oninput` 这样事件处理属性来绑定事件处理函数。需要提醒大家的是,这种写法在实际开发中应该杜绝。
15+
16+
具体原因请参考这篇文章:[《前端进阶之路:点击事件绑定》](https://github.com/cssmagic/blog/issues/48)。
17+
18+
19+
#### 第 169 页 ‧ 侧栏的 “小提示” 区块
20+
21+
> 如果用 `input:in-range` 来代替简单的 `input` 选择符,就可以**只在浏览器支持范围输入控件时才对它设置样式**。接下来,我们就可以利用层叠机制把它在旧版浏览器下隐藏掉或设置为其他样式。
22+
23+
如果浏览器不支持范围输入控件,会发生什么?如果浏览器不支持范围输入控件(`type="range"`),则会把它当作普通的文本输入框(`type="text"`)来对待——这也算是 HTML 的一种回退机制。此时,范围输入控件会被浏览器渲染为一个文件输入框,在这种情况下,我们显然不能把它暴露出来。
24+
25+
因此作者在这里提示我们做好善后工作。这里的 `input:in-range` 就像是一种特性检测,可以把浏览器区分为两类,然后针对它们分别设置样式。
26+
27+
这里对 `input:in-range` 选择符的运用堪称巧妙。对于范围输入控件来说,它的值总是在合法的范围内(因为你无法把滑块拖到滑轨的范围之外),这个伪类选择符总是会选中范围输入控件。
28+
29+
另外,你可能会问,这里用 `input[type="range"]` 选择符可以起到相同的作用吗?其实并不行。因为不论浏览器在 HTML 层面是否支持范围输入控件,只要它在 CSS 层面支持属性选择符,就总是可以匹配到 `<input type="range">` 这个元素。所以这个选择符起不到特性检测的作用。
30+
31+
32+
#### 第 170 页 ‧ 第一段
33+
34+
> 这个范围输入控件只是随便放在图片下面而已……我们需要用一点 CSS 来**把它定位到图片之上**,并让它与图片一样宽:
35+
36+
> ```
37+
> ...
38+
> left: 0;
39+
> ...
40+
> width: 100%;
41+
> ...
42+
> ```
43+
44+
既然已经是绝对定位了,那在把滑块控件设置为跟图片等宽时,为什么不用 `left: 0``right: 0`,而用 `width: 100%`
45+
46+
因为替换元素拥有它自己与生俱来的宽度和高度(比如图片元素就是它自己的宽高,而输入控件的天生宽高大多是由浏览器的渲染引擎或默认样式来决定的),我们无法用 `left: 0``right: 0` 来把它拉伸为包含块的宽度,而必须用 `width: 100%` 显式指定。
47+
48+
49+
#### 第 170 页 ‧ 第二段
50+
51+
> 一些私有的伪元素可以为这个滑块控件进一步设置样式,比如 `::-moz-range-track``::-ms-track``::-webkit-slider-thumb``::-moz-range-thumb``::-ms-thumb` 等。
52+
53+
滑轨和滑块总是成对出现的,因此原文缺了一个 `::-webkit-slider-runnable-track`
54+
55+
相关资源:
56+
57+
* http://brennaobrien.com/blog/2014/05/style-input-type-range-in-every-browser.html
58+
* https://css-tricks.com/styling-cross-browser-compatible-range-inputs-css/
59+
* http://codepen.io/collection/DgYaMj/
60+

0 commit comments

Comments
 (0)