1. 选择器:高级选择器:属性选择器:[] ,例如:a[href=”#”] {};选择器的优先级:!important为最高优先级,其次优先级次序规则:a,b,c,d ,a代表行内样式,b代表ID选择器,c代表类、伪类、属性选择器,d代表类型元素选择器和伪元素选择器,它们的基数是1000,100,10,1;
  2. 设计良好的CSS样式表:①结构(自上而下):一般样式:主体样式、reset样式、链接、标题、其他元素;辅助样式:表单、通知和错误、一致的条目;页面结构:标题、页脚和导航;页面组件:各个页面;覆盖②注释:开发期间,在样式表的最开头把最常用的颜色16进制注释出来,开发完成后删除。可以使用不同标识符来表示哪些代码可能在以后需要更改,哪些是浏览器遇到的问题
  3. 可视化格式模型:①盒模型:IE6早期的盒模型width属性包括内容、内边距以及边框的综合,而现在的盒模型width属性只指内容;②普通流的块元素的外边距叠加问题:当两个垂直外边距相遇时,它们会发生叠加,这个外边距的高度将会等于两个外边距中较大的那个,无论这个元素是父元素与子元素还是相邻元素之间,但在行内框、浮动元素以及绝对定位的元素不会发生上述情况;③行内框:行内框的尺寸只受行高、水平内外边距以及边框的影响;④相对定位:相对定位会占据原来的空间,移动会导致它覆盖其它框;⑤绝对定位:相对于距离它最近的已定位的祖先元素,所以要在绝对定位的父级设置成相对定位,可以通过设置z-index来控制层叠次序;⑥浮动:浮动框左右移动直到移动到父级边框或者另一个浮动框的边缘,行框将会围绕在浮动框的周围,如果不想行框在浮动框周围,则把行框clear设置成both,也可以通过设置overflow:hidden/auto产生的副作用清除浮动
  4. 对链接应用样式::link表示没有访问过的链接,:visited表示访问过的链接,:hover,:foucs,:active,注意它们的选择器特殊性可能会导致层叠,因而采用LVHFA的先后次序,一般情况下是取消默认的下划线,在鼠标悬停或者激活链接时添加下划线,在不同状态下且无需再次加载更换背景图片的技巧:采用雪碧图,在不同状态控制图片的不同偏移位置显示不同的图片
  5. 对列表应用样式和创建导航栏:如果需要为列表符号添加特定的符号,可以把默认的项目符号去掉,留出内边距,用背景图像代替即可;为了在菜单栏上创建斜面的效果,一般把顶边框设置得比背景颜色浅,而底边框则深一点;纯CSS实现下拉菜单:在li标签里面嵌套ul>li标签,然后父元素li标签相对定位,子元素ul绝对定位,display为none,悬浮时显示出来;表单元素样式,可以通过直接在lable里面添加表单控件,也可以通过for的方式在外边添加表单控件,通常为了提示用户以及反馈给用户哪些单是必须填的可以使用em/span元素进行提示和标记
  6. 布局:①结构设计:先把页面划分为大的结构性区域,比如容器、页眉、页脚、内容区域,然后将注意力转移到内容区域本身,开始建立网格结构,最后在各个内容区域中寻找不同的布局结构;②分析不同类型的内容,查看每个内容块的结构,看看不同的类型中是否有相同的模式,找出模式并命名约定后,开始定义即将使用的元素;③布局类型:浮动布局:a.两列的浮动布局:在一个主体容器中分成左右两个容器并左右浮动,主体容器可以采用溢出的方法清除浮动;b.三列布局:在两列布局的基础上,在其中一个容器添加两个容器,并使得这两个容器左右浮动,父容器本身也要浮动,相当于四个容器都浮动;固定宽度、流式布局和弹性布局:固定宽度采用固定像素,流式布局采用百分比,弹性布局采用em,流式布局和弹性布局都要注意min-width和max-width;设置三个列相同高度的技巧:在一个主体容器中,放置三个容器,这三个容器高度由内容撑开,然后设置底边距为主容器的高度,再把overflow设置成hidden
  7. bug和修复bug:①选择器特殊性次序导致样式不成效问题;②外边距叠加问题;常见bug及其修复方法:

精通CSS:高级WEB解决方案的更多相关文章

  1. 精通CSS高级Web标准解决方案(1-1选择器)

    设计代码的结构 使用有意义的标记 css可以控制页面的外观并将表现与内容分隔开. 在分配ID与类名时尽量保证有意义且与表现无关. div可以对块级元素进行分组,而span可以对行内元素进行分组或标识. ...

  2. 精通css 高级web标准解决方案——可视化格式模型-定位模型

    CSS 中有三种定位机制:普通流.浮动.绝对定位.(默认为普通流) 改变文档流:display: inline-block; (支持到ie8及以上) 1-匿名块框: <div> 你好! & ...

  3. 精通css 高级web标准解决方案——可视化格式模型-盒模型

    1-盒模型的两种标准: IE :width 和 height属性 是包括padding和border在内的. w3c:width 和 height 属性,就是单纯的内容的宽高,padding 是内容之 ...

  4. 精通CSS高级Web标准解决方案(4、对链接应用样式)

    4.1 简单的链接样式 锚可以作为内部引用,也可以作为外部链接,应该区分对待. 伪类选择器: :link 用来寻找没有访问过的链接 :visited 用来寻找已经访问过的链接 a:link{color ...

  5. 精通CSS高级Web标准解决方案(2-2 可视化格式模型之定位概述)

    视觉格式化模型 块级元素(块框).行内元素(行内框),可以使用display改变生成的框的类型,display:block让行内元素(比如<a>)表现的跟块级元素一样,display:no ...

  6. 精通CSS高级Web标准解决方案(2-1 可视化格式模型之框模型)

    浮动.定位.框模型这些控制在页面上安排和显示元素的方式,形成CSS布局. 盒子模型 页面上的每个元素都被看成一个矩形框. 盒子模型有两种,分别是 IE 盒子模型和标准 W3C 盒子模型.他们对盒子模型 ...

  7. 精通CSS高级Web标准解决方案(1-3 规划、组织与维护样式表)

    对文档应用样式 对代码进行注释/*......*/ 结构性注释 自我提示 删除注释.优化样式表 样式指南:解释代码与站点的视觉设计是如何组织在一起的 站点结构.文件结构.命名规则 编码标准:(X)ht ...

  8. web前端好书推荐 CSS权威指南《第3版,Bootstrap实战,精通CSS 高级Web标准解决方案 第2版 中文

    在我的新博客中==> http://www.suanliutudousi.com/2017/08/24/web%E5%89%8D%E7%AB%AF%E5%A5%BD%E4%B9%A6%E6%8E ...

  9. 精通CSS高级Web标准解决方案(1-2 层叠与特殊性)

     层叠与特殊性 选择器的特殊性分成四个等级,a.b.c . d 如果样式是行内样式,那么a=1 b=ID选择器的总数 c=类.伪类.属性选择器的总数 d=标签选择器与伪元素选择器数量 例如:style ...

随机推荐

  1. 设置onselectstart在ie浏览器下对于input及textarea标签页会生效

    设置onselectstart在ie浏览器下对于input及textarea标签页会生效, 可以使用js来控制对于某种标签不生效,代码如下: document.onselectstart = disa ...

  2. jsp项目中整个项目没有问题但是servlet报错

    项目没问题但是serverlet报错 项目右键 buildPath-->configure build path -->Myeclipse Library-->J2EE 1.3 Li ...

  3. BZOJ1085 luogu2324骑士精神题解

    没有什么特别好的办法,只好用搜索去做 因为一次移动最多归位一个骑士 所以可以想到用IDA*,为了简化状态 我们用k,x,y,sum来表示移动了k步,空格在x,y,还用sum个没有归位的情况 然后枚举转 ...

  4. MyBatis动态SQL(一)

    MyBatis 的强大特性之一便是它的动态 SQL.动态 SQL 元素和 JSTL 或基于类似 XML 的文本处理器相似.在 MyBatis 之前的版本中,有很多元素需要花时间了解.MyBatis 3 ...

  5. 【Leetcode链表】反转链表(206)

    题目 反转一个单链表. 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 进阶: 你可 ...

  6. Atcoder Tenka1 Programmer Contest C C - 4/N

    http://tenka1-2017.contest.atcoder.jp/tasks/tenka1_2017_c 我怀疑我是不是智障.... 本来一直的想法是能不能构造出答案,把N按奇偶分,偶数好办 ...

  7. linux下arm平台Qt编译环境搭建与解析

    一.概述:      我们知道QTcreator.这仅仅是个IDE,他包含了一个编译器--qmake.这两者的关系与codeblocks和g++的关系一样,首先要明确这些.      而我们在linu ...

  8. 从零学React Native之05混合开发

    本篇文章,我们主要讨论如何实现Android平台的混合开发. RN给Android端发送消息 首先打开Android Studio, Open工程, 在React Native项目目录下选择andro ...

  9. 字母间距letter-spacing

    效果图: 字母间距CSS: h1 {letter-spacing:2px} h2 {letter-spacing:-3px}

  10. PHP 网站大流量与高并发的解决方法

    php 网站如何应对大流量与高并发呢? 首先,确认服务器硬件是否足够支持当前的流量. 普通的P4服务器一般最多能支持每天10万地理IP,如果访问量比这个还要大,则请配置一台更高性能的专用服务器. 否则 ...