入门13 CSS综合

CSS编码规范

  • 命名规范:
    语义化标签优先;基于功能命名、基于内容命名、基于表现命名;简略、明了、无后患
常见命名1
    .wrap or .wrapper -- 用于外侧包裹
    .container or .ct -- 包裹容器
    .header -- 用于头部
    .body -- 页面 body
    .footer -- 页面尾部
    .aside or .sidebar -- 用于侧边栏
    .content -- 和header footer 对应,用于主要内容
    .navigation -- 导航元素
    .pagination -- 分页
常见命名2
    .tabs > .tab -- tab 切换
    .breadcrumbs -- 导航列表、面包屑
    .dropdown -- 下拉菜单
    .article -- 文章
    .main -- 用于主体
    .thumbnail -- 头像,小图像
    .media -- 媒体资源
    .panel -- 面板
    .tooltip -- 鼠标放置上去的提示
    .popup -- 鼠标点击弹出的提示
常见命名3
    .button、.btn -- 按钮
    .ad -- 广告
    .subnav -- 二级导航
    .menu -- 菜单
    .tag -- 标签
    .message或者.notice -- 提示消息
    .summary -- 摘要
    .logo -- logo
    .search -- 搜索框
    .login -- 登录
常见命名4
    .register -- 注册
    .username -- 用户名
    .password -- 密码
    .banner -- 广告条
    .copyright -- 版权
    .modal或者 .dialog -- 弹窗
常见命名5
var 名字 = { 
     状态: [ 'inverse', 'toggled', 'switched', 'original', 'initial', 'identified',  'disabled', 'loading', 'pending', 'syncing', 'default' ], 
     修饰: [ 'dark', 'light', 'shaded', 'flat', 'ghost', 'maroon', 'pale', 'intense', 'twisted', 'narrow', 'wide', 'smooth', 'separate', 'clean', 'sharp', 'aligned' ], 
     元素: [ 'pagination', 'modal', 'popup', 'article', 'story', 'flash', 'status', 'state', 'media', 'block', 'card', 'teaser', 'badge', 'label', 'sheet', 'poster', 'notice', 'record', 'entry', 'item', 'figure', 'square', 'module', 'bar', 'button', 'action', 'knob' ], 
     布局: [ 'navigation', 'wrapper', 'inner', 'header', 'footer', 'aside', 'section', 'divider', 'content', 'container', 'panel', 'pane', 'construct', 'composition', 'spacing', 'frame' ] }
  • 书写规范:
  1. 用两个空格来代替制表符(tab) -- 这是唯一能保证在所有环境下获得一致展现的方法。
  2. 为选择器分组时,将单独的选择器单独放在一行。
  3. 为了代码的易读性,在每个声明块的左花括号前添加一个空格。
  4. 声明块的右花括号应当单独成行。
  5. 每条声明语句的:后应该插入一个空格。
  6. 为了获得更准确的错误报告,每条声明都应该独占一行。
  7. 所有声明语句都应当以分号结尾。最后一条声明语句后面的分号是可选的,但是,如果省略这个分号,你的代码可能更易出错。
  8. 对于以逗号分隔的属性值,每个逗号后面都应该插入一个空格(例如, box-shadow)。
  9. 不要在rgb()rgba()hsl()hsla()rect()值的内部的逗号后面插入空格。这样利于从多个属性值(既加逗号也加空格)中区分多个颜色值(只加逗号,不加空格)。
  10. 对于属性值或颜色参数,省略小于 1 的小数前面的 0 (例如,.5
    代替0.5-.5px代替-0.5px)。
  11. 十六进制值应该全部小写,例如,#fff。在扫描文档时,小写字符易于分辨,因为他们的形式更易于区分。尽量使用简写形式的十六进制值,例如,用#fff代替#ffffff
  12. 为选择器中的属性添加双引号,例如,input[type="text"]。只有在某些情况下是可选的,但是,为了代码的一致性,建议都加上双引号。
  13. 避免为 0 值指定单位,例如,用margin: 0;代替margin: 0px;
  • 声明顺序:
    相关的属性声明应当归为一组,并按照下面的顺序排列:
    1. Positioning(布局方式、位置):position / top / right / bottom / left / float / display / overflow
    2. Box model(盒模型、尺寸):border / margin / padding / width / height
    3. Typographic(文本相关):font / line-height / text-align / word-wrap
    4. Visual(视觉效果):background / color / transition / list-style

由于定位(positioning)可以从正常的文档流中移除元素,并且还能覆盖盒模型(box model)相关的样式,因此排在首位。盒模型排在第二位,因为它决定了组件的尺寸和位置。
其他属性只是影响组件的内部(inside)或者是不影响前两组属性,因此排在后面。

垂直居中有4种实现方式

  • 上下padding相等实现居中
html
<body>
  <div class="content">
    <p>我爱学习,学习使我快乐</p>
    <p>我爱学习,学习使我快乐</p>
    <p>我爱学习,学习使我快乐</p>
    <p>我爱学习,学习使我快乐</p>
  </div>
</body>
css
.content {
  border: 1px solid red;
  margin: 20px auto;
  padding: 50px 0;
  text-align: center;
}
.content>p {
  border: 1px solid green;
}
上下padding相等
  • 绝对定位实现居中
html
<body>
  <div class="dialog">
    <header>来自网页的消息:</header>
    <p>欢迎来到饥人谷~最有爱的前端学习社区~~</p>
  </div>
</body>
css
.dialog {
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -120px;
  margin-top: -80px;
  width: 240px;
  height: 160px;
  border: 1px solid #ddd;
  border-radius: 10px;
  box-shadow: 0 0 3px #aaa;
}
.dialog>header {
  padding: 10px;
  background: #000;
  border-radius: 9px 9px 0 0;
  color: #fff;
}
.dialog>p {
  padding: 20px;
}
绝对定位

注:widthheight属性不固定时,可用transform: translate(-50%,-50%)代替margin-left: ; margin-right: ;

  • vertical-align:middle实现居中
html
<div class="box">
   ![](http://upload-images.jianshu.io/upload_images/6426975-67235bded916bb39.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
 </div>
css
.box {
  width: 400px;
  height: 200px;
  border: 1px solid orange;
  text-align: center;
}
.box:before {
  content:"";
  display: inline-block;
  height: 100%;
  vertical-align: middle;
}
.box>img {
  width: 180px;
  vertical-align: middle;
  background: #a0a0a0;
}
vertical-align
  • table-cell实现居中
html同上
css
.box {
  width: 400px;
  height: 200px;
  border: 1px solid orange;
  text-align: center;
  display: table-cell;
  vertical-align: middle;
}
.box>img {
  width: 180px;
  background: #a0a0a0;
}
效果同上

实现如下效果

效果范例

代码

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容

  • 各种纯css图标 CSS3可以实现很多漂亮的图形,我收集了32种图形,在下面列出。直接用CSS3画出这些图形,要比...
    剑残阅读 9,176评论 0 8
  • 移动开发基本知识点 一.使用rem作为单位 html { font-size: 100px; } @media(m...
    横冲直撞666阅读 3,377评论 0 6
  • H5移动端知识点总结 阅读目录 移动开发基本知识点 calc基本用法 box-sizing的理解及使用 理解dis...
    Mx勇阅读 4,282评论 0 26
  • 我曾经很想念一个人 我以为只是曾经 没想 时至今日 我还是会常常想念同一个人 一条街如果尽头很远 花草树木会不会 ...
    零启阅读 346评论 0 0
  • 科学研究已经证实,大多数癌症的病因与生活方式有关。美国癌症研究所出版的《癌症止步》一书中就指出,77%的癌症根源在...
    芳芳健康分享阅读 435评论 0 0