漫谈SMACSS_html/css_WEB-ITnose
SMACSS (Scalable and Modular Architecture for CSS)发音同“smacks”,它不是框架,不是库。它只是一种组织CSS代码的方法论(或者说是为了让代码可扩展,易维护的一套规范,它会使团队开发更容易)。每个人看世界的角度不同,方法论因人而异,所以这套玩意儿不一定适合你。
CSS分类
按照SMACSS可以分为5类:
-
Base—— 通常是一些默认样式,reset.css ,normalize.css 之类
html, body, form { margin: 0;}input[type=text] { border: 1px solid #999;}a { color: #390;}
登录后复制 -
Layout—— Layout 则是将页面分成几个部分,一个 Layout 中可以有一个或多个Module
.nav {}.footer {}.sidebar {}
登录后复制 -
Module—— 这个部分是可复用,模块化的代码,比如弹出框,汉堡按钮。
.panel {}.panel-body {}
登录后复制 -
State—— 状态是用来描述Layout,Module的特殊样式。
.is-hidden {}
登录后复制 -
Theme—— Theme是定义多种主题
命名规则
通常使用 l- 前缀标记这个类名是 Layout, is- 前缀标记为状态类等等,而Modules不需要,该是什么名字就叫什么。
/* Example Module */.example { }/* Callout Module */.callout { }/* Callout Module with State */.callout.is-collapsed { }/* Inline layout */.l-inline { }
属性分组
修改css属性时,我们常常需要肉眼搜索目标属性。如果属性杂乱无章,那么我们得花更多的时间查找。有人开发过按css属性字母顺序排列的插件,个人认为不好用,比如需要修改宽高时,需要找到height,再找到width,还是挺麻烦。而通常这类参数是成组出现的。
我们可以按照下列顺序书写:
- Box ( display, float, position, left, top, height, width… )
- Border ( border, border-image, border-radius… )
- Background ( background-color, background-image… )
- Text ( font-family, font-size, text-transform… )
- Other ( other )
选择器性能优化
CSS选择器从右到左进行匹配
body div#content p { color: #003366; }
在浏览器查找到p元素的时候,就会往上找是否有div#content这样的父元素,若找到了,则继续向上搜索,知道匹配成功,添加到渲染树中;若找不到,则匹配失败,这块样式不起作用。
控制好饮食,小心吃撑:虽然后代选择器很方便,但是从上面的分析看出来,没遇到p元素,我们都要执行一次向上搜索,代价显然是很昂贵的。
遵循下面三条规范可以帮助你健身:
- 使用子类选择器(’>’,IE6我对不起你)
- 避免使用常用的标签选择器
- 最右选择器使用类名
比如你DOM中有一打H3,假设使用 .module h3 这样的选择器,那么对于 html > body > div > div > ... > h3 这样的节点,向上搜索的路径就长了去。改成 .module > h3 我们只需要搜索24个元素。
颜色声明
尽量使用3或6位的16进制颜色值,因为它们足够简洁。rgb,hsl就稍微有点长了。当然rgba, hsla就避免不了,因为十六进制没有alpha值。
文件组织
- 把所有基本样式放在单独文件
- layout 取决你文件的大小,细化成多个文件或者是放在同一个文件
- 每个模块都独立一个文件
- 子模块取决于项目的大小
- 全局states放在单独文件
- layout,modules states 以及 media queries 放在相应的 modules 文件中
结合Sass, 文件树如下:
+-layout/ | +-grid.scss | +-alternate.scss +-module/ | +-callout.scss | +-bookmarks.scss | +-btn.scss | +-btn-compose.scss +-base.scss +-states.scss
然后在main.scss中引入,
@import "base", "states", "layout/grid", "module/btn", ...
最终产出一个 main.css 文件。可以参考 jonathanpath 的 SASS-SMACSS, github地址
其他资源
CSS Preprocessors
- LESS
- Sass
其他方法论
- OOCSS
- BEM
文档
- Front-end Style Guides
其他资源
- mustache 是一个轻逻辑的模板语言,不受环境影响。
更高级的规范
- 墙裂推荐 Hugo Giraudel 的 Sass Guidelines
彩蛋
我买了 SMACSS 电子书 ,这篇文章是我的学习笔记 + 要点总结。如有需要,留下邮箱,我可以把电子书共享给你(仅供学习交流使用),或者扫描 WeChat 二维码加我为好友。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

HTML、CSS和JavaScript是Web开发的三大支柱。1.HTML定义网页结构,使用标签如、等。2.CSS控制网页样式,使用选择器和属性如color、font-size等。3.JavaScript实现动态效果和交互,通过事件监听和DOM操作。

HTML、CSS和JavaScript在Web开发中的作用分别是:1.HTML定义网页结构,2.CSS控制网页样式,3.JavaScript添加动态行为。它们共同构建了现代网站的框架、美观和交互性。

HTML的未来趋势是语义化和Web组件,CSS的未来趋势是CSS-in-JS和CSSHoudini,JavaScript的未来趋势是WebAssembly和Serverless。1.HTML的语义化提高可访问性和SEO效果,Web组件提升开发效率但需注意浏览器兼容性。2.CSS-in-JS增强样式管理灵活性但可能增大文件体积,CSSHoudini允许直接操作CSS渲染。3.WebAssembly优化浏览器应用性能但学习曲线陡,Serverless简化开发但需优化冷启动问题。

HTML的未来充满了无限可能。1)新功能和标准将包括更多的语义化标签和WebComponents的普及。2)网页设计趋势将继续向响应式和无障碍设计发展。3)性能优化将通过响应式图片加载和延迟加载技术提升用户体验。

HTML、CSS和JavaScript在网页开发中的角色分别是:HTML负责内容结构,CSS负责样式,JavaScript负责动态行为。1.HTML通过标签定义网页结构和内容,确保语义化。2.CSS通过选择器和属性控制网页样式,使其美观易读。3.JavaScript通过脚本控制网页行为,实现动态和交互功能。

HTML是构建网页结构的基石。1.HTML定义内容结构和语义,使用、、等标签。2.提供语义化标记,如、、等,提升SEO效果。3.通过标签实现用户交互,需注意表单验证。4.使用、等高级元素结合JavaScript实现动态效果。5.常见错误包括标签未闭合和属性值未加引号,需使用验证工具。6.优化策略包括减少HTTP请求、压缩HTML、使用语义化标签等。

HTML的作用是通过标签和属性定义网页的结构和内容。1.HTML通过到、等标签组织内容,使其易于阅读和理解。2.使用语义化标签如、等增强可访问性和SEO。3.优化HTML代码可以提高网页加载速度和用户体验。
