阿里社招p8面试流程,CSS 中的分离、抽象和层叠,CSS的行内样式与内联样式

通常,我们这样写css:

div.main { background-color: green; text-color: yellow; border: 1px solid red; margin-top: 10px;}blockquote { background-color: green; text-color: yellow; border: 1px solid red;}p { margin-top: 10px;}

这样看起来似乎不是很糟,但是仍存在一些重复的定义。我们可以采用另一种方式。

/* Dorothy style */div.main, blockquote { background-color: green; text-color: yellow; border: 1px solid red;}/* Top margin */div.main, p { margin-top: 10px;}


如果我们需要给div.footer定义个上边距,我们只需要把他添加到选择器里面就行,不用重新定一个规则了。我确信别人已经想到了这种风格的写法(或许起了个更好的名字),但是我不知道。我想这也是css作者的初衷之一吧。在实际中,以我的经验来看,这样的方式很难做到。不知为何,我没有这样的习惯去保持样式从他们的规则中独立出来。css属性和div.main,blockquote相关联,但是不符合dorothy(一种样式风格)第一条原则。也许专业人士能做的更好,但我从来没遇见过。

使用LESS就没这些问题。我只需要定义一个混合类,然后在我需要的地方复用它就可以了。

层叠

对于层叠问题LESS和SASS提出了一种很好的解决方案,但是有一定的局限性。层叠是复杂性中最基本的一个问题。对于一个特定元素的特定的属性,有很多地方的值是需要设定的。然而确定这些所有地方的优先权的规则是很复杂的。

一个元素的最终CSS属性值是由以下因素决定的:

  • 导入CSS的顺序
  • CSS规则中定义的class的数量
  • 在文件中定义的规则的顺序
  • 所有的继承的属性设置
  • 元素的 tag name
  • 元素的 class
  • 元素的 id
  • HTML树中所有元素的祖先元素
  • 浏览器的默认样式

确实,css样式属性被很多影响着,但,智者总会让所有事情保持干净和简单。其实,保持这种智慧行为仅仅在小项目中有效,但在其他一些时候,层叠样式将会伤害到你。

Jason Zimdars 在37 Signals展现了他们提出的层叠样式的解决方案,他分享了一些关于层叠问题的分析和LESS怎么能消除层叠问题的观点。

如果css的层叠可以受控制,我们将第一次能够明确自己写的css不会引起问题,这将促使我们创造带有自身包含的样式表的元素,这些元素放之四海皆有效!

内容和样式的分离听起来像圣杯一样响亮!

通过使用嵌套的LESS规则和子选择器,我们能够避免大多数的层叠带来的痛。联合其他的一些技巧,我们能够将我们的样式混合到一块(或者是混合中嵌套混合),并将这些样式和通过模仿html结构的嵌套规则绑定到一块。

这是完美的,最终的解决方案吗?不一定!

将来

也有其他一些尝试解决层叠问题的方法,LESS和Sass被用来作为css的父集,这就意味着你可用的css文件就自动的成为LESS文件,同时也意味着你一开始就得用LESS编译器。

在这种情况下,LESS将会同事拥有所有css没有解决的问题,我建议在下一步可以尝试采用css子集并加以实践,同时,也非常希望听到大家的意见!

是的,嵌套规则确实可以处理层叠问题,但是也有其他关于层叠的问题。样式的混合不能真的帮你解决盒模型,再多的变量和算法也不能让两个DIV的宽度相同。

接下来,我将一个一个的解决这些问题。

再次“层叠”

直率的说,层叠就是css的创作者犯的一个错误,层叠的运用一开始希望是美好的,但在实际的运用中表现的并不理想。

事后诸葛亮,各个浏览器统一的层叠样式真的是我们所需要的,CSS reset真的是一项漂亮的发明,它精彩的解决了不同浏览器之间的默认样式的不同,它可以让你不用考虑默认样式轻松的开始页面的制作,所以,css reset可以实现页面样式默认,但除此之外,它中间的一些样式可能不能被充分的利用。

有的时候,你可能会想用层叠,例如,你想要设置整个文档的字体,所以, 你设置 body{ font-family:'Comic Sans';},0K,间接的利用font-famiy属性的继承性便将整个文档的字体搞定了。事实上,如果你想每个标签都有同样的属性,可以这样写:* {font-family:'Comic Sans';},其实这和css reset 有异曲同工之妙,都是为样式设置默认样式 。

这意味着一条原则:一次性地重置一些默认样式并避免使用样式重叠。接下来我们需要能系统地遵循此原则。这是新的代码结构的样子:

不使用样式重叠意味着我们必须严格要求自己不在同一页面元素上应用多个样式规则。我无法告诉你要怎么做才能严格达到此要求,但是有些准则是可以参考的。

  1. 重置默认样式的规则只使用bare (classless + non-nested) selectors。
  2. LESS规则中不要用bare selectors。
  3. LESS规则中不要有重复的选择器。

这些准则会限制样式重叠的出现次数,再结合使用Zimdars提出的解决方案,效果会更佳。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

最后

面试一面会问很多基础问题,而这些基础问题基本上在网上搜索,面试题都会很多很多。最好把准备一下常见的面试问题,毕竟面试也相当与一次考试,所以找工作面试的准备千万别偷懒。面试就跟考试一样的,时间长了不复习,现场表现肯定不会太好。表现的不好面试官不可能说,我猜他没发挥好,我录用他吧。

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

96道前端面试题:

常用算法面试题:

前端基础面试题:
内容主要包括HTML,CSS,JavaScript,浏览器,性能优化

一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!

AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算

开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值