16.设计—下-灵析社区

懒人学前端

六、多方法隐藏元素

七、实现文字描边

  • text-shadow

<style>
div {
font-size: 100px;
color: #fff;
text-shadow: 0 0 3px black;
}
</style>
<div>文字描边</div>
  • -webkit-text-stroke

<style>
div {
font-size: 100px;
color: #fff;
-webkit-text-stroke: 3px black;
}
</style>
<div>文字描边</div>
  • position: relative/position: absolute子绝父相

<style>
div {
position: relative;
font-size: 100px;
color: #fff;
}
div p {
position: absolute;
margin: 0;
}
div p:first-child {
font-weight: bolder;
color: black;
}
</style>
<div>
<p>文字描边</p>
<p>文字描边</p>
</div>

八、实现渐变背景

  • 背景图片

一张宽 1px 像素,高度沿渐变方向固定,重复铺满即可

<style>
div {
  height: 250px;
  background-image: url();
  background-repeat: repeat-x;
  background-size: 1px 100%;
}
</style>
<div></div>
  • linear-gradient
<style>
div {
  height: 250px;
  background-image: linear-gradient(to bottom, pink, skyblue);
}
</style>
<div></div>

九、对比常见图片格式和 base64 图片?

可以将图片转为 Base64 编码,直接将编码放入 CSS 中,即可引入图片

编码后的图片通常比原图大 30% 或更多,但可以与 CSS 一起被 gzip 或 br 压缩

适用小图片和没有权限上传图片的场景,来减少请求,但也应设置代码编辑器不换行或折叠图片编码区域,避免影响 CSS可读性

十、为什么要重置浏览器默认样式,对比 Reset.css 和 Normalize.css?

什么是浏览器默认样式

对于部分HTML标签,如段落、列表,部分表单元素,浏览器会提供默认样式,包含外观及交互,开发者只需引入标签,不需要重复定义这些样式,便于开发

为什么要重置默认样式

  • 不同浏览器,默认样式可能不同,特别是尺寸,位置的不同,让开发者无法统一用户体验,甚至有错位的风险
  • 只使用标签的语义,而不想引入样式
  • UI稿与浏览器默认样式不同

基于以上,都需要开发者重置或部分重置浏览器的默认样式,以满足开发需求

对比常用的 Reset.css 和 Normalize.css

共同点

  • 两者都能抹平浏览器间的默认样式差异
  • 都部分重置了浏览器默认样式,尤其是内外边距属性

不同点

  • Reset.css让元素在不同浏览器样式完全一样
  • Normalize.css适当保留部分浏览器默认样式,只重置影响开发的样式,此外

Normalize.css修复了表单、SVG溢出等BUG

Normalize.css适当提高了可用性

Normalize.css避免大量使用群组选择器,通过注释提高调试体验

最佳实践

对于绝大多数小型项目:

  • 只重置在页面中使用到的标签
  • 只重置有默认属性的属性名
  • 适当保留浏览器的默认样式,如表单的outline

阅读量:1998

点赞量:0

收藏量:0