• CSS3基础——笔记+实战案例(CSS基本用法、CSS层叠性、CSS继承性)


    CSS3基础——笔记

      CSS是Cascading Style Sheet的缩写,翻译为"层叠样式表" 或 "级联样式表"。CSS定义如何显示HTML的标签央视,用于设计网页的外观效果。通过使用CSS实现页面的内容与表现形式分离,极大提高了工作效率。

    一、CSS基础用法

       CSS代码可以在任何文本编辑器中打开和编辑。因此,不管读者有没有变成基础,初次接触CSS时会感到很简单。

    1.1 CSS样式

      样式是CSS最小的语法单元,每个样式包含两部分内容:选择器和声明(规则),如下所示:

    CSS样式基本结构-图1.1

    • 选择器(Selector): 选择器告诉浏览器呢该样式将作用于页面中哪些对象,这些对象可以是某个标签、所有网页对象、指定Class或ID值等。浏览器在解析这个样式时,根据选择器来渲染对象的显示效果。
    • 声明(Declaration): 声明可以增加一个或者无数个,这些声明命令浏览器如何去渲染选择器指定的对象。声明必须包括两部分:属性和属性值,并用分号来标识一个声明的结束,在一个样式中最后一个声明可以省略分号。所有声明被放置在一对大括号内,然后整体紧邻选择器的后面。
    • 属性(Property): 属性是CSS提供的设置好的样式选项。属性名是一个单词或多个单词组成,多个单词之间通过连字符相连。这样能够直观表示属性所要设置样式的效果。
    • 属性值(Value): 属性值是用来显示属性效果的参数。它包括数值和单位,或者关键字。

    1.2 CSS应用

      CSS样式代码必须保存在.css类型的文本中,或者放在网页内<style>标签中,或者插在网页标签的style属性中。CSS样式应用的方法主要包括4种: 

    1、行内样式:行内样式就是把CSS样式直接放在代码行内的标签中,一般都放入标签的style属性中。

    这种方法是修改最不方便的样式! 

    <!DOCTYPE html>
    <html>
     <head>
      <meta charset="UTF-8" />
      <title>css行内样式</title>
     </head>
     <body>
      <div style="100px;height:100px;background:red;"></div>&gt; 
     </body>
    </html>

    2、内嵌式: 内嵌式通过CSS卸载网页源文件的头部,即在<head>与</head>之间,通过使用HTML标签中的<style>标签将其包围,其特点是:该样式只能在此页使用,

    这种方法解决行内样式多次书写的弊端!

    <html>
     <head></head>
     <body>
      !doctype html&gt;
      <meta charset="UTF-8" />
      <title>css内嵌样式</title>
      <style type="text/css">#div{width:100px;height:100px;background:red;}</style>
      <div id="div"></div>&gt; 
     </body>
    </html>

    3、链接式:链接式通过HTML的<link>标签,将外部样式表文件链接到HTML文档中,这也是网络上网站引用最多的方式,同时也是最实用的方式。

    这种方法将HTML文档和CSS文件完全分离,实现结构层和表示层的彻底分离,增强网页结构的扩展性和CSS样式的可维护性。 

    <!DOCTYPE html>
    <html>
     <head>
      <meta charset="UTF-8" />
      <title>css内嵌样式</title>
      <link rel="stylesheet" type="text/css" href="ccss.css" />
     </head>
     <body>
      <div id="div"></div>&gt;
     </body>
    </html>

     4、导入样式:导入样式使用@import命令导入外部样式表。

    <!DOCTYPE html>
    <html lang="zh-cn">
     <head> 
      <meta charset="utf-8" /> 
      <title>@import_CSS使用@import命令导入外部样式表</title> 
      <style>
    @import url("style.css") screen, print;
    </style> 
     </head> 
     <body></body>
    </html>

    两种导入样式表的方法比较:

    1 link属于HTML标签,而@important是CSS提供的。
    2 页面被加载的时,link会同时被加载,而@important引用的CSS会等到页面被加载完再加载。
    3 @important只在IE5以上才能识别,而link是HTML标签,无兼容问题。
    4 link方式的样式的权重高于@important的权重。
    5 因此,一般推荐link导入样式表的方法,@important可以作为补充方法使用。

    1.3 CSS注释

      在CSS中增加注释很简单,所有被放在"/*"和"*/"分隔符之间的文本信息都被称为注释。

    /* 下面这段代码的作用是建立网页布局 start */
    .header{
       960px;
    }
    /* 下面这段代码的作用是建立网页布局 end */
    
    /* 整段代码注释:
    下面这段代码的作用是建立网页布局,它包括头部和尾部宽度设置 start  */
    .header{960px;}
    .footer{960px;}
    /*下面这段代码的作用是建立网页布局
     它包括头部和尾部宽度设置 end */

     二、 CSS特性(非常重要)

      层叠继承是CSS样式两个基本的特性。本节将对CSS特性分别进行详细说明,并通过示例演示CSS特性在网页设计中的应用。

    2.1 CSS层叠性 

      1、CSS样式表的优先级: 按照CSS的起源可以将网页定义的样式分为4种: HTML、作者、用户、浏览器。

    a) HTML表示元素的默认样式;作者就是创建人,即创建网站所编辑的CSS;用户也就是浏览网页的人所设置的样式;浏览器就是指浏览器默认的样式。

    b) 原则上讲,作者定义的样式优先于用户设置的样式,用户设置的样式优先于浏览器的默认样式,而浏览器的默认样式会优先于HTML的默认样式。

      2、CSS样式的优先级: 对于相同CSS起源来说,不同位置的样式其优先级也是不相同的。

    一般来说,行内样式会优先于内嵌式表,内部样式会优先于外部样式表。而被附加了!important关键字的声明会拥有最高的优先级。

      如果多个不同类型的选择器同时为一个对象设置样式时,该对象将如何显示最终样式呢?以下给出一个简单的计算方法。对于常规选择器,它们拥有一个优先级加权值,说明如下:

    • 标签选择器: 优先级加权值为1;
    • 伪元素或伪对象选择器: 优先级加权值为1;
    • 类选择器: 优先级加权值为10;
    • 属性选择器: 优先级加权值为10;
    • ID选择器: 优先级加权值为100;
    • 其他选择器: 优先级加权值为0,如统配选择器等。

    然后,以上面加权值数加起点来计算每个样式中选择器的总加权值数。计算的规则是:

    • 统计选择器中ID选择器的个数,然后乘于100;
    • 统计选择器中类选择器的个数,然后乘于10;
    • 统计选择器中标签选择器的个数,然后乘于1;

     以此方法类推,最后把所有加权值数相加,即可得到当前选择器的总加权值,最后根据加权值来决定哪个样式的优先级大。

    对于由多个选择器组合而成的复合选择器,首先分别计算每个组成选择器的加权值,接着相加得出当前选择器的总分,最后根据选择器的分值大小,分值越高则优先级越高,那么就将应用它所设置的样式。如果分值相同,则根据位置关系来进行判断,越靠近对象的样式就拥有越高的优先级。

    2.2 CSS继承性

      所谓继承性,就是指被包含的元素将用于外层元素的样式效果。继承性最典型的应用就是在默认样式的预设上。

     

      我们先从文档树(HTML DOM)开始。文档树由HTML元素组成。文档树和家族树类似,也有祖先、后代、父亲、孩子和兄弟。这很容易理解吧,笔者在这里就不一一赘述了。希望深入了解的朋友请google之。

    那么CSS样式表继承指的是,特定的CSS属性向下传递到子孙元素。

    不是所有的属性都可以继承,只有以color/font-/text-/line开头的属性才可以继承。
    在css中的继承不仅是儿子才可以继承,只要是后代就可以继承
    css继承性中的特殊性。a标签的文字颜色和下划线是不能被继承的,h标签的文字大小是不能被继承的。
    应用场景: 一般用于设置网页上的一些共性信息。
    

    CSS基础——实战案例

       以上部分是理论基础知识的介绍,下面我们开始着案例来涉及一个完整的页面,帮助自己加深理解。

    【操作步骤】

    (1) 使用文本编辑器(我使用Notepad++),新建HTML文件,保存为index.html。

    <html>
    <head>
    </head>
    <body>
    </body>
    </html>

    (2) 切换到<body></body>标签内输入以下代码,用来构建本页面主体结构,设计本页面一级框架。

    <html>
    <head>
    </head>
    <body>
    <!--[一级框架]-->
    <!--顶部-->
    <div id="top"></div>
    <div id="top1"></div>
    <!--主体-->
    <div id="main"></div>
    <!--底部-->
    <div id="footer"></div>
    <div id="copyright"></div>
    </body>
    </html>
    

      在标准布局中,影噶为每个div框架元素定义id属性,这些id属性如同人的身份证一样,方便CSS能够准确控制每个div布局块。所以,为了阅读和维护的需要,我们应该为它们起一个有意义的名字。

    (3) 进一步细化页面结构,设计页面内部层次框架。由于本例页面比较简单,嵌套框架不会很深,顶部和底部布局块可能就不要嵌套框架。输入完整的HTML结构代码:

    <html>
    <head>
    </head>
    <body>
    <!--[完整 HTML 框架]-->
    <!--顶部-->
    <div id="top"></div>
    <div id="top1"><img src="http://image.baidu.com/search/detail?ct=503316480&z=undefined&tn=baiduimagedetail&ipn=d&word=CSS3%20%E5%9B%BE%E7%89%87&step_word=&ie=utf-8&in=&cl=2&lm=-1&st=undefined&cs=3225363744,4220361311&os=3377850775,544686624&simid=4252198847,742695430&pn=1&rn=1&di=56730334650&ln=1869&fr=&fmq=1533315991177_R&fm=&ic=undefined&s=undefined&se=&sme=&tab=0&width=undefined&height=undefined&face=undefined&is=0,0&istype=0&ist=&jit=&bdtype=0&spn=0&pi=0&gsm=0&objurl=http%3A%2F%2Fwww.xuejiqiao.com%2Fuploads%2Fimage%2F20140912%2F14104879608470.jpg&rpstart=0&rpnum=0&adpicid=0" ></div>
    <!--主体-->
    <div id="main">
      <div id="content">
        <div id="titile">Hello World --  第一个 CSS3+DIV页面</div>
        <div class="sub">实例</div>
        <div class="box"><div class="t1"><div class="tr"><div class="b1"><div class="content br"></div>
    <!--底部-->
    <div id="footer"></div>
    <div id="copyright"></div>
    </body>
    </html>
    

    (4) 丰富结构内容,使用<pre>标签显示代码内容,使用<a>设计超链接文本,整个页面内容显示如下,代码内容是在网页中居中显示红色字符"Hello World!" 

    <html>
    <head>
    </head>
    <body>
    <!--[完整 HTML 框架]-->
    <!--顶部-->
    <div id="top"></div>
    <div id="top1"><img src="http://file01.16sucai.com/d/file/2010/1026/20101026011522224.jpg"></div>
    <!--主体-->
    <div id="main">
      <div id="content">
        <div id="titile">Hello World --  第一个 CSS3+DIV页面</div>
        <div class="sub">实例</div>
        <div class="box"><div class="t1"><div class="tr"><div class="b1"><div class="content br"></div>
    <pre>
    <!doctype html>
    <html>
      <head>
        <meta charset="utf-8">
        <title>Hello Wold</title>
        <style type="text/css">
        h1 {
        	color: #FF0000; /*元素文本颜色Red*/
        	text-align: center; /*元素文本的对齐方式*/
        }
        </style>
      </head>
    <body>
      <h1>Hello World!</h1>
    </body>
    </html>
    </pre>
    </div></div><div></div></div>
    <div id="gotop"><a titile="跳到页首" href="#top">返回顶部</a></div>
    </div>
    <!--底部-->
    <div id="footer"></div>
    <div id="copyright">
      ©2017 <a href="#" target="_black" >mysite.cn</a> all rights reserved
    </div>
    </body>
    </html>
    

    (5) 按Ctrl+S快捷键保存文档,按F12键在浏览器中预览,则显示如下所示,现在还没有定义CSS代码,所以看到的效果还不是最终效果。

      

    (6) 编写CSS代码可以在一个单独的文件中进行。新建images文件夹,文件夹内创建CSS文档,保存为style.css,文件扩展名为.css。

    (7) 不急于编写CSS代码,打开index.html文档,然后在<head>标签内插入一个<link>标签,输入以下代码导入上一步新建的外部样式表文件。

    <head>
      <!--[在网页中链接外部样式表文件]-->
      <link href="images/style.css" type=text/css rel=stylesheet>
    </head>
    

    (8) 打开style.css文档,在其中输入CSS代码如下:

    /*公共属性
    ----------------------*/
    html{min-776px;}
    
    /*页面属性:边距为0,字体颜色为黑色,字体大小14像素,行高为字体大小1.6倍,居中对齐,背景色为天蓝色,字体为宋体等*/
    body{
    	margin:0px;
    	padding:0px;
    	border:0px;
    	color:#000;
    	font-size:14px;
    	line-height:160%;
    	text-align:center;
    	background:#6D89DD;
    	font-family:'宋体','新宋体',arial,verdana,sans-serif;
    }
    
    /*超连接属性: 无边距、无边框,无下划线,然后定义正常状态下的颜色、访问过的颜色和鼠标经过的颜色并显示下划线*/
    a{
    	margin:0px;
    	padding:0px;
    	border:0px;
    	text-decoration:none; /*这个属性允许对文本设置某种效果,如加下划线*/
    }
    a:link{color: #FF0000}   /* 未访问的链接 */
    a:visited{color:E66133}  /* 已访问的链接 */
    a:hover{color: #FF00FF; text-decoration:underline;} /* 当有鼠标悬停在链接上;定义文本下的一条线 */
    
    /*预定义格式属性:浅灰色北京,无首行缩进,内边距大小,外边距为0,右缩进为一个字体大小,字体颜色为蓝色 */
    pre{
    	text-indent:0;/*用于定义块级元素中第一个内容行的缩进 */
    	background:#DDDDDD;
    	padding:0px;
    	margin:0px;
    	color:blue;
    }
    
    /**顶部布局
    ----------------------*/
    #top{
    	776px;
    	margin-right:auto;
    	margin-left:auto;
    	padding:0px;
    	height:12px;
    	background: url(images/bg_dot1.gif) #fff repeat-x left top; 
    	overflow:hidden;
    }
    #top1{
    	776px;
    	margin-right:auto;
    	margin-left:auto;
    	padding:0px;
    	height:121px;
    }
    
    /*主体布局
    ----------------------*/
    /*外层定义背景图像,实现麻点显示效果 */
    #main{
    	776px;
    	margin-right:auto;
    	margin-left:auto;
    	padding:1.2em 0px;
    	background:url(images/bg_dot2.gif) #fff repeat left top;
    	text-align:left;
    }
    /*内层定义背景颜色为白色,实现中间内容区域遮盖麻点显示 */
    #content{
    	710px;
    	margin-right:auto;
    	margin-left:auto;
    	padding:1em;
    	background:#fff;
    }
    /*大标题区域属性*/
    #titile{
    	font-weight:bold;
    	margin:0px 0px 0.5em 0px;
    	padding:0.5em 0px 0.5em 1em;
    	font-size: 24px;
    	color:#00A06B;
    	text-align:left;
    	border-bottom:solid #9EA3C1 2px;
    }
    /*小标题区域属性*/
    .sub{
    	color:#00A06B;
    	font-weight:13px;
    	text-align:left;
    	padding:1em 2em 0;
    	background:url(images/0.gif) #fff no-repeat 1em 74%;
    }
    /*内容区域显示属性*/
    .content{
    	text-indent:2em;
    	font-size:13px;
    	margin-left:2em;
    	padding:1em 6px;
    }
    /*页面链接区域属性*/
    #gotop{
    	100%;
    	margin:0px;
    	padding:0px;
    	background:#fff;
    	height:2em;
    	font-size:12px;
    	text-align:right;
    }
    /*底部布局
    ----------------------*/
    /*页脚装修图*/
    #footer{
    	clear:both;
    	776px;
    	margin-right:auto;
    	margin-left:auto;
    	padding:0px;
    	background:url(images/bg_bottom.gif) #fff repeat left top;
    	text-align:center;
    	height:39px;
    	color:#ddd;
    }
    /*版权信息*/
    #copyright{
    	776px;
    	margin-right:auto;
    	margin-left:auto;
    	padding:5px 0px 0px 0px;
    	background:url(images/bg_bottom.gif) #fff; 
    	text-align:center;
    	height:60px;
    	line-height:13px;
    	font-size:12px;
    	color:#93A0BB;
    }
    /*圆角特效
    ----------------------*/
    .box{background:url(images/nt.gif) repeat;}
    .tl{background:url(images/tl.gif) no-repeat top left;}
    .tr{background:url(images/tr.gif) no-repeat top right;}
    .bl{background:url(images/bl.gif) no-repeat bottom left;}
    .br{background:url(images/br.gif) no-repeat bottom right;}
    

    (9) 按Ctrl+S保存文档,然后在浏览器中再次预览页面,则可以看到最终效果。images文件夹下的gif删除了,所以展示不全,不过大部分都出来了,就懒得重新去把图片找出来了。

  • 相关阅读:
    OpenStack--Rabbitmq组件消息队列
    Redis-主从
    haproxy mycat mysql 读写分离MHA高可用
    mysql小白系列_14 线上故障分析与排错
    mysql小白系列_13 Online DDL
    mysql小白系列_12 sysbench
    mysql小白系列_11 MHA补充
    mysql小白系列_11 MHA
    mysql小白系列_10 mysql主从复制原理
    mysql小白系列_09 mysql性能优化关键点
  • 原文地址:https://www.cnblogs.com/zuoyang/p/9393757.html
Copyright © 2020-2023  润新知