发表于: 2018-06-16 23:10:01
2 559
今天完成的事情:
1.基于昨天拆分的全局样式,用sass完成了任务7的重构
明天计划的事情:
1.做任务13的侧边导航汉堡菜单
2.提交任务13,写任务13的任务总结并更新wiki
3.开始任务14的前期准备
4.做好请假手续,准备请假两天半回家办事(18号-20号上午)
遇到的问题:
1.在用兄弟选择器+和~时,对这两个选择器的用法理解不深,这两个选择器只能选所用标签之后的兄弟标签,之前的兄弟标签是选不到的,在这里卡了很长时间,还做了demo验证。选择器只能向下或向后选,不能向上或向前选。
2.在样式头部定义font-size:62.5%时一定要定义在html里,只在body中定义的话不起作用。
3.在实现任务7投票页的小格子的样式和字体大小都能宽度自适应时,应该将全部的尺寸都换算成vw单位,包括字体的尺寸。
4.在做任务7结果页恭喜语时,需要实现一个效果:视窗宽度变大时,文字变成单行自然居中;视窗宽度变小时,文字变成多行,也能多行居中,但是多行文字应左对齐。效果图如下:
视窗宽度大时:
视窗宽度小时:
实现这个效果应使用span标签,因为span标签的盒子宽度会跟随一行字体的宽度改变而改变,而h1,p等标签没有这个效果,span标签应设置display:inline-block;text-align: left(或者justify);包裹span的div应设置text-align:center。
收获:
1.CSS 相邻兄弟选择器
相邻兄弟选择器(Adjacent sibling selector)可选择紧接在另一元素后的元素,且二者有相同父元素。
如果需要选择紧接在另一个元素后的元素,而且二者有相同的父元素,可以使用相邻兄弟选择器(Adjacent sibling selector)。
例如,如果要增加紧接在 h1 元素后出现的段落的上边距,可以这样写:
h1 + p {margin-top:50px;}
这个选择器读作:“选择紧接在 h1 元素后出现的段落,h1 和 p 元素拥有共同的父元素”。
相邻兄弟选择器使用了加号(+),即相邻兄弟结合符(Adjacent sibling combinator)。
注释:与子结合符一样,相邻兄弟结合符旁边可以有空白符。
请看下面这个文档树片段:
<div>
<ul>
<li>List item 1</li>
<li>List item 2</li>
<li>List item 3</li>
</ul>
<ol>
<li>List item 1</li>
<li>List item 2</li>
<li>List item 3</li>
</ol>
</div>
在上面的片段中,div 元素中包含两个列表:一个无序列表,一个有序列表,每个列表都包含三个列表项。这两个列表是相邻兄弟,列表项本身也是相邻兄弟。不过,第一个列表中的列表项与第二个列表中的列表项不是相邻兄弟,因为这两组列表项不属于同一父元素(最多只能算堂兄弟)。
请记住,用一个结合符只能选择两个相邻兄弟中的第二个元素。请看下面的选择器:
li + li {font-weight:bold;}
上面这个选择器只会把列表中的第二个和第三个列表项变为粗体。第一个列表项不受影响。
~ 选择器作用是查找某一个指定元素的后面的所有兄弟结点。
示例代码:
运行结果:
2.如何做默认样式重置?resetting 和 normalizing 之间有什么区别?
常用的几个主流浏览器中, 当我们没有给html元素设置样式时,这些浏览器会根据自己的默认样式对html元素进行布局,但是由于每个浏览器的默认布局样式不同, 会导致元素的展示方式出现差异,从而使同一页面在不同浏览器中的展示出现差异。使用CSS样式重置这一方式,就可以使网页展示效果保持 一致。
什么是CSS RESET?
在HTML标签在浏览器里有默认的样式,例如 p 标签有上下边距,strong标签有字体加粗样式,em标签有字体倾斜样式。不同浏览器的默认样式之间也会有差别,例如ul默认带有缩进的样式,在IE下,它的缩进是通过margin实现的,而Firefox下,它的缩进是由padding实现的。在切换页面的时候,浏览器的默认样式往往会给我们带来麻烦,影响开发效率。所以解决的方法就是一开始就将浏览器的默认样式全部去掉,更准确说就是通过重新定义标签样式。“覆盖”浏览器的CSS默认属性。最最简单的说法就是把浏览器提供的默认样式覆盖掉!这就是CSS reset。
CSS Reset的作用:
CSS Reset让各个浏览器的CSS样式有一个统一的基准,而实现这一基准最主要的方式就是“清零”
举例:
* { outline: 0; padding: 0; margin: 0; border: 0; } 其中 * 就是常说的通配符,意思是“所有的”。使用 * 代表所有的标签或元素,就叫做通配符选择器。
由于 * 会匹配所有的元素,所以当浏览器解析到 * 时,会将页面内的所有标签都进行如上的样式重置, 这样会影响网页渲染的时间,所以使用 * 时一定要慎重,尽量不要在样式重置时应用 * 。
什么是NORMALIZE?
Normalize.css 只是一个很小的CSS文件,但它在默认的HTML元素样式上 提供了跨浏览器的高度一致性。相比于传统的CSS reset,Normalize.css 是一种现代的、为HTML5准备的优质替代方案。Normalize.css现在已经被 用于Twitter Bootstrap、HTML5 Boilerplate、GOV.UK、Rdio、CSS Tricks 以及许许多多其他框架、工具和网站上。
normalize创造的目的:
保护有用的浏览器默认样式而不是完全去掉它们
一般化的样式:为大部分HTML元素提供
修复浏览器自身的bug并保证各浏览器的一致性
优化CSS可用性:用一些小技巧
解释代码:用注释和详细的文档来
RESET和NORMALIZE的区别:
(1) Normalize.css 保护了有价值的默认值
Reset通过为几乎所有的元素施加默认样式,强行使得元素有相同的视觉效果。 相比之下,Normalize.css保持了许多默认的浏览器样式。这就意味着你不用再 为所有公共的排版元素重新设置样式。当一个元素在不同的浏览器中有不同的默认值时, Normalize.css会力求让这些样式保持一致并尽可能与现代标准相符合。
(2)Normalize.css 修复了浏览器的bug
它修复了常见的桌面端和移动端浏览器的bug。 这往往超出了Reset所能做到的范畴。关于这一点, Normalize.css修复的问题包含了HTML5元素的显示设置、 预格式化文字的font-size问题、在IE9中SVG的溢出、许多 出现在各浏览器和操作系统中的与表单相关的bug。
(3)Normalize.css 不会让你的调试工具变的杂乱
使用Reset最让人困扰的地方莫过于在浏览器调试工具中大段大段的继承链, 如下图所示。在Normalize.css中就不会有这样的问题,因为在我们的准则中 对多选择器的使用时非常谨慎的,我们仅会有目的地对目标元素设置样式。
(4)Normalize.css 是模块化的
这个项目已经被拆分为多个相关却又独立的部分, 这使得你能够很容易也很清楚地知道哪些元素被设置了特定的值。 因此这能让你自己选择性地移除掉某些永远不会用到部分(比如表单的一般化)。
(5)Normalize.css 拥有详细的文档
Normalize.css的代码基于详细而全面的跨浏览器研究与测试。 这个文件中拥有详细的代码说明并在Github Wiki中有进一步的说明。 这意味着你可以找到每一行代码具体完成了什么工作、为什么要写这句代码、 浏览器之间的差异,并且你可以更容易地进行自己的测试。
进度:css任务13
任务开始时间:2018.6.15
预计demo时间:2018.6.16
是否有延期风险:有(错估了任务难度,预计延期一天)
禅道:http://task.ptteng.com/zentao/project-task-719.html
评论