这段时间做了一个简单的页面,借机又重温了一下CSS的相关知识,现总结一下:

  • 工欲善其事必先利其器,让我们先做一点准备工作

    1.在页面添加:

<meta http-equiv="x-ua-compatible" content="ie=edge"> 

  指定IE利用标准模式渲染页面,而不是兼容模式

<meta name="viewport" content="width=device-width,initial-scale=1"> 

  viewport的属性
  width:控制 viewport 的大小,可以指定的一个值,如果 600,或者特殊的值,如 device-width 为设备的宽度(单位为缩放为 100% 时的 CSS 的像素)。
  height:和 width 相对应,指定高度
  initial-scale:初始缩放比例,也即是当页面第一次 load 的时候缩放比例
  maximum-scale:允许用户缩放到的最大比例
  minimum-scale:允许用户缩放到的最小比例
  user-scalable:用户是否可以手动缩放,默认为yes

  2.引入normalize.css

    多数时候我们都用reset.css来去除或规范一些浏览器的默认样式,normallize.css 较之 reset.css 提供了更好的样式跨浏览器一致性体验。

    normalize.css

    来,让我们谈一谈 Normalize.css   微吐槽:实际项目中normalize没有去除ul的padding等类似的值,谁能告诉我为什么?

  3.利用BrowserSync来调整编辑页面

    这个工具真的很强大,支持sass和less的实时编辑预览,再也不用担心save & F5了。(下载页面)

  4.多用Can I Use(http://caniuse.com/)

    不仅列出各浏览器的支持程度,还能提供一些issues文档,多查查你肯定会收获更多。

  • 项目实践中的一点经验总结

  1.固定背景

    视差效果是越来越流行了,其实我觉得设置一个固定背景就能实现一个最简单的视差效果,提升你的网站bigger。


      
background-attachment: fixed 使背景图不随页面的滚动而滚动
      background-size: cover 使背景图始终填满整个屏幕
      background-position: center; 使背景图居中
      更多background属性参考

  2.关于Collapsing Margins
    常见的相邻两个块级元素垂直margin合并、子元素margin传递到父级margin其实都是Collapsing Margin 惹的祸。详细介绍可以参考collapsing-margins.其中针对margin传递问题可用设置border或padding处理。

  3.关于overflow:hidden的两个实现原理

    当文字和图片同级且同时设置浮动时:

    

    有时我们并不想让文字全包围图片,而是这样

    

    没有设置overflow:hidden时,文字内容的容器与外部容器左边界是重合的, 修改后,这个容器内的内容(context)属性变为了block formating contexts(参考block-formatting  以及 bfc-next-to-float),直接效果就是图片和文字各自的容器在同时浮动时不再有重合的部分。  

    更多内容可参考:CSS 101: Block Formatting Contexts


            How does the CSS Block Formatting Context work?

    另外常见到用overflow:hidden来清除浮动,其原理是:容器在计算自身高度的时候必须要有足够的高度包围所有的子元素。但 float 的元素 (还有绝对定位的元素)并不包含在这个计算里面,设置overflow就可以改变容器计算高度的方式让容器 float 元素包含在高度计算内。(参考: bfc-next-to-float

  4.简化布局的border-box
    盒模型(content-box)在计算宽度(width)时是不包括border\padding的,所以如果用width:25%设置一排四个均匀分布的span时,很可能得不到想要的效果。这时将其转化为border-    box(width=content+padding+border)模型就能很好的完成需求.参考box-sizing

  5.绝对定位(absolute)
    常用的绝对定位的场景是:针对正常布局的主要页面元素(设置参考  position:relative)将其辅助的页面组件设置为position:absolute,列入下拉菜单,弹出的菜单选项就是辅助组件。

    

    这里需要注意的是,辅助组件一定要设置宽度(百分比或指定宽度皆可),否则器宽度会变得不确定。

  6.一些关于语义化实现的细节
    标题文字下装饰性的下划线、指示用的小三角符号以及清除浮动都可以借助伪元素(:after和:before)来实现,更好遵循样式和内容分离的原则。
    此外在页面引入nav/section/header/article等标签能更好遵守语义化(Semantic)规范。语义化Semantic参考 另外 normalize.css帮我们处理好了IE8-浏览器对新标签元素的支持问题。

  7.怎能忘记响应式
    响应式的页面不仅仅是包括了可以解决因屏幕大小而产生布局问题的Media Query,还要考虑到因带宽小和高延迟带来的资源加载、用户体验等问题。可参考Resposive Disgn

    先说到这里,有可吐槽的地方,欢迎拍砖。

关于CSS的只言片语的更多相关文章

  1. Matplotlib数据可视化(3):文本与轴

      在一幅图表中,文本.坐标轴和图像的是信息传递的核心,对着三者的设置是作图这最为关心的内容,在上一篇博客中虽然列举了一些设置方法,但没有进行深入介绍,本文以围绕如何对文本和坐标轴进行设置展开(对图像 ...

  2. css sprites-简单实例让你快速掌握css sprites精髓

    这段时间有几次接触到了css sprites的概念,一个就是在用css做滑动门的时候,另外一个就是在用YSlow分析网站性能的时候,于是对css sprites这个概念产生了浓厚的兴趣.在网上查找了很 ...

  3. 模仿某旅行网站 纯css实现背景放大效果

    基本功能是鼠标移动到图片上,对应宽度变宽.其中布局和基本样式直接copy官网,功能部分是自己瞎鼓捣实现的. 直接上代码: HTML部分 <div class="fold_wrap&qu ...

  4. CSS的未来

    仅供参考 前言 完成<CSS核心技术与实战>这本书,已有一个多月了,而这篇文章原本是打算写在那本书里面的,但本章讲解的内容,毕竟属于CSS未来的范畴,而这一切都还不能够确定下来,所以这一章 ...

  5. 前端极易被误导的css选择器权重计算及css内联样式的妙用技巧

    记得大学时候,专业课的网页设计书籍里面讲过css选择器权重的计算:id是100,class是10,html标签是5等等,然后全部加起来的和进行比较... 我只想说:真是误人子弟,害人不浅! 最近,在前 ...

  6. 前端css兼容性与易混淆的点

    一.常用的骨灰级清除浮动 .clearfix:after { content: "."; display: block; height:; clear: both; visibil ...

  7. 理解CSS外边距margin

    前面的话   margin是盒模型几个属性中一个非常特殊的属性.简单举几个例子:只有margin不显示当前元素背景,只有margin可以设置为负值,margin和宽高支持auto,以及margin具有 ...

  8. 理解CSS视觉格式化

    前面的话   CSS视觉格式化这个词可能比较陌生,但说起盒模型可能就恍然大悟了.实际上,盒模型只是CSS视觉格式化的一部分.视觉格式化分为块级和行内两种处理方式.理解视觉格式化,可以确定得到的效果是应 ...

  9. 谈谈一些有趣的CSS题目(十二)-- 你该知道的字体 font-family

    开本系列,谈谈一些有趣的 CSS 题目,题目类型天马行空,想到什么说什么,不仅为了拓宽一下解决问题的思路,更涉及一些容易忽视的 CSS 细节. 解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题 ...

随机推荐

  1. CloudStack4.2 二级镜像存储测试

    //添加二级存储{ "addimagestoreresponse": { "imagestore": { "id": "2dda4 ...

  2. Linux系统编程——进程间通信:命名管道(FIFO)

    命名管道的概述 无名管道,因为没有名字,仅仅能用于亲缘关系的进程间通信(很多其它详情.请看<无名管道>).为了克服这个缺点.提出了命名管道(FIFO).也叫有名管道.FIFO 文件. 命名 ...

  3. 【M34】如何在同一个程序中结合C++和C

    1.C++和C混合编程的时候,需要考虑产生的目标文件的兼容性. 2.名称重整,为什么要搞出名称重整? 连接器要求所有方法名必须独一无二.对于C语言,没问题.C++支持过载,也就是方法名相同,形参表不同 ...

  4. 容器的end()方法

    容器的end()方法,返回一个迭代器,需要注意:这个迭代器不指向实际的元素,而是表示末端元素的下一个元素,这个迭代器起一个哨兵的作用,表示已经处理完所有的元素. 因此,在查找的时候,返回的迭代器,不等 ...

  5. jQuery分别获取选中的复选框值

    function jqchk(){  //jquery获取复选框值   var s='';   $('input[name="aihao"]:checked').each(func ...

  6. 【JavaScript】JavaScript模块化编程 - CommonJS, AMD 和 RequireJS之间的关系

    通行的Javascript模块规范共有两种:CommonJS和AMD 先说说CommonJS   CommonJS - 大家是不是觉得JavaScript仅仅是一个客户端的编译语言,其实JavaScr ...

  7. window.onload与$.ready的差别

    在做图书管理系统的时候.实用到window.onload(){}方法.可是遇到了一个问题.就是怎么都不运行,究竟是为什么呢?愁了半天.后来经师姐指点改用了$.ready(){}. 在我的浅浅的了解中觉 ...

  8. System.setProperty()

    /*  * 设置指定键对值的系统属性  * setProperty (String prop, String value);  *  * 參数:  * prop - 系统属性的名称.  * value ...

  9. 调用百度地图Api实现的查看地图功能的小插件

    1. 功能 bMap.js 可根据地理位置调用出百度地图,采用弹出框形式 2.用法 var city = '青岛市'; var address = '香港中路'; bMap.init({ city : ...

  10. Web service是什么?(转)

    我认为,下一代互联网软件将建立在Web service(也就是"云")的基础上. 我把学习笔记和学习心得,放到网志上,欢迎指正. 今天先写一个最基本的问题,Web service到 ...