层叠样式表


本章将阐述CSS的基本规则。

解构CSS


所谓CSS,由选择器(selector)和声明块(declaration block)组成。再进一步细分,每个声明包括了属性和值。

selector:{
property:value;
}

内联还是外链?


大多时候显然是外链更高效。样式文件可以缓存到用户电脑,如果你一个网站用一套css,当用户访问同一个网站其它页面时,就不用再次加载样式。

然而,缓存对于开发者来说是个坏东西。在本地调试时,修改样式表之后可能无法马上看到变化这时应该通过ctrl+F5来强制刷新清空缓存。

内联样式

同在在head标记内建一个style标记,样式在里面写。在H5以前的规范中,style必须加上属性type="text/css",现在已经不作要求。如果head内还有javascript,需要把script标记放到样式的后面。

单个网页而言,内联样式相对较快,但是可维护性较差。

外链样式

外链样式起名随意,但是最好是相关的。全站的表单用同一套样式时,可以命名为form.css。

对于外链css还可以使用在线工具进行验证。http://jigsaw.w3.org/css-validator/

外链css必须关联。可以选择<link>标记也可以用@import来指向想要被引用的css,浏览器对此二者的解释并无区别。

link

h5的link调用格式为:

<link rel="stylesheet" href="css/styles.css">

xhtml的格式为:

<link type="texxt/css" rel="stylesheet" href="....."/>

h5省略了type="texxt/css"

通过@import调用:
<style>
@import url(css/style.css)/*路径加不加引号都可以*/
</style>

@import的不同之处:link语法属于html,而@import属于css语言,作为css语言,意味着你还可以在后面继续写其它css。这样一来,style内的css就是一个关联了其它样式的样式文件。可以认为是内联样式的一种变体。需要在网页加载之后才开始加载。最大的问题:不支持javascript控制DOM修改样式。

小结:有研究指出,在某些时候,采用@import方式引入的css会拖慢速度,因此建议只使用link。

两者都是外部引用CSS的方式,但是存在一定的区别:

第一个样式


比如说一个html5文档信息如下:

<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>CSS:The Missing Manual -- Chapter 2</title>
</head> <body>
<h1>CSS: The Missing Manual</h1>
<p>...(假文) </p>
<h2>标题2</h2>
<p>...(假文)</p>
<p>...(假文)</p>
<h2>Nisi Ut Aliquid </h2>
<p>...(假文)</p>
<p>...(假文)</p>
<address>
Copyright 2016, Dang Jingtao
</address>
</body>
</html>

行间样式

行间样式并非一无是处:比如邮件等明确要有的信息。

比如:

<h1 style="color:#666:font-size:3em;">

内联样式

<style>
/*格式化h1*/
h1{
color:#666;
font-size:3em;
margin-top:10px;
margin-left:80px;
}
/*格式化段落*/
p{
color:#616161;
line-height: 150%;
margin-top:10px;
margin-left: 80px;
}
</style>

外链css

在网页文件head元素中关联:

<link rel="stylesheet" href="styles.css">

在根目录下的styles.css文件写入CSS:

/*格式化页面*/
html{
/*上内间距25px*/
padding-top:25px;
background-image:url(images/bg_page.png);
}
body{
width: 80%;
padding:20px;
margin:0 auto;
box-shadow: 10px 10px 10px rgba(0,0,0,.5);
background-color: #e1edeb;
} /*格式化h1*/
h1{
font-family: 'Gravitas One','Arial Black',serif;
font-weight: normal;
color:#666;
font-size:3em;
margin-top:10px;
margin-left:80px;
}
/*格式化段落*/
p{
color:#616161;
line-height: 150%;
margin-top:10px;
margin-left: 80px;
}

初步效果如下:



对于用户的系统字体不满意的话可以采用谷歌字体:

<link rel="stylesheet" href="http://fonts.googleleaps.com/css?family=Gravitas+One">

根据同样的机制,可以给文档加上更丰富的样式(字体,色彩,边距)

html {
padding-top: 25px;
background-image: url(images/bg_page.png);
}
body {
width: 80%;
padding: 20px;
box-shadow: 10px 10px 10px rgba(0,0,0,.5);
margin: 0 auto;
background-color: #E1EDEB;
}
h1 {
color: #666666;
font-size: 3em;
font-family: 'Gravitas One', 'Arial Black', serif;
font-weight: normal;
margin: 0;
} p {
font-family: "Palatino Linotype", Baskerville, serif;
color: #616161;
line-height: 150%;
margin-top: 10px;
margin-left: 60px;
}
h2 {
color: #B1967C;
font-family: 'Gravitas One', 'Arial Black', serif;
font-weight: normal;
font-size: 2.2em;
border-bottom: 2px white solid;
background: url(images/head-icon.png) no-repeat 10px 10px;
padding: 0 0 2px 60px;
margin: 0;
}
.intro {
color: #6A94CC;
font-family: Arial, Helvetica, sans-serif;
font-size: 1.2em;
margin-left: 0;
margin-bottom: 25px;
}

最后效果:(在线字体引用失败时可翻墙试试)

技巧总结:


  • 响应式居中可以直接用body百分比宽度,居中实现,可以加阴影。html文档的背景可以实现网页背景纹理,不需要body上做文章。

《CSS3实战》读书笔记 第2章 层叠样式表(CSS)的更多相关文章

  1. Spring3.x企业开发应用实战读书笔记 —— 第三章IoC容器概述

    声明:    本篇博客绝大多数内容为<Spring3.x企业开发应用实战>一书原内容,所有版权归原书作者所有!,仅供学习参考,勿作他用! 3.2 相关Java基础知识 Java语言允许通过 ...

  2. jQuery 实战读书笔记之第二章:选择元素

    基本选择器 html 代码如下,后面的 js 使用的 html 基本大同小异. <!doctype html> <html> <head> <title> ...

  3. Spring AOP (Spring 3.x 企业应用开发实战读书笔记第六章)

    从面相对象编程到面相切面编程,是一种代码组织方式的进化. 每一代的代码组织方式,其实是为了解决当时面对的问题.比如写编译器和写操作系统的时候的年代当然要pop,比如写界面的时候当然要oop,因为界面这 ...

  4. 机器学习实战 - 读书笔记(13) - 利用PCA来简化数据

    前言 最近在看Peter Harrington写的"机器学习实战",这是我的学习心得,这次是第13章 - 利用PCA来简化数据. 这里介绍,机器学习中的降维技术,可简化样品数据. ...

  5. 机器学习实战 - 读书笔记(12) - 使用FP-growth算法来高效发现频繁项集

    前言 最近在看Peter Harrington写的"机器学习实战",这是我的学习心得,这次是第12章 - 使用FP-growth算法来高效发现频繁项集. 基本概念 FP-growt ...

  6. 机器学习实战 - 读书笔记(11) - 使用Apriori算法进行关联分析

    前言 最近在看Peter Harrington写的"机器学习实战",这是我的学习心得,这次是第11章 - 使用Apriori算法进行关联分析. 基本概念 关联分析(associat ...

  7. 机器学习实战 - 读书笔记(07) - 利用AdaBoost元算法提高分类性能

    前言 最近在看Peter Harrington写的"机器学习实战",这是我的学习笔记,这次是第7章 - 利用AdaBoost元算法提高分类性能. 核心思想 在使用某个特定的算法是, ...

  8. iPhone与iPad开发实战读书笔记

    iPhone开发一些读书笔记 手机应用分类1.教育工具2.生活工具3.社交应用4.定位工具5.游戏6.报纸和杂志的阅读器7.移动办公应用8.财经工具9.手机购物应用10.风景区相关应用11.旅游相关的 ...

  9. <<Java RESTful Web Service实战>> 读书笔记

    <<Java RESTful Web Service实战>> 读书笔记 第一章   JAX-RS2.0入门 REST (Representational State ransf ...

随机推荐

  1. TouchSlop与VelocityTracker认识

    TouchSlop是处理触摸事件中的一个常量,被系统认为滑动和点击事件的临界点.理 解这个touchSlop是一个滑动距离值的常量,也就是说当我们手触摸在屏幕上滑动时,如果滑动距离没有超过touchS ...

  2. 三大范式与BCNF

    引用:http://www.cnblogs.com/ybwang/archive/2010/06/04/1751279.html 参考: 1.范式间的区别 http://www.cnblogs.com ...

  3. sql-schema与catalog

    schema: 指的是说当偶create database caiceclb时,caiceclb就是一个schema catalog: 指的是所有的database目录,就像上图显示的那样,将MySQ ...

  4. R语言之RCurl实现文件批量下载

    前言: RCurl工具包的作者是由Duncan Temple Lang现任加州大学 U.C. Davis分校副教授.他曾致力于借助统计整合进行信息技术的探索.使用者通过RCurl可以轻易访问网页,进行 ...

  5. 用 unoconv 将 xls 转换成 csv

    在 Linux 下,用 unoconv 将 xls 转换成 csv. unoconv -f csv -v input.xlsx

  6. 【BZOJ-1031】字符加密Cipher 后缀数组

    1031: [JSOI2007]字符加密Cipher Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 5504  Solved: 2277[Submit ...

  7. jquery插件-表单提交插件-jQuery.Form

    1.介绍 JQuery Form插件是一款强大的Ajax表单提交插件,可以简单方便的实现让我们的表单 由传统的提交方式转换成Ajax无刷新提交! 他提供了两个核心的方法ajaxForm以及ajaxSu ...

  8. php des 加密解密实例

    des加密是对称加密中在互联网应用的比较多的一种加密方式,php 通过mcrypt扩展库来支持des加密,要在Php中使用des加密,需要先安装mcrypt扩展库 $iv_size = mcrypt_ ...

  9. [iOS Keychain本地长期键值存储]

    目前本地存储方式大致有:Sqlite,Coredata,NSUserdefaults.但他们都是在删除APP后就会被删除,如果长期使用存储,可以使用Keychain钥匙串来实现. CHKeychain ...

  10. Scala可变长度参数

    可变长度参数 Scala 允许你指明函数的最后一个参数可以是重复的.这可以允许客户向函数传入可变长度参数列表.想要标注一个重复参数,在参数的类型之后放一个星号.例如: scala> def ec ...