css语法和基本知识

1、CSS全称为“层叠样式表”,它主要是用于定义HTML内容在浏览器内的显示样式,如文字大小、颜色、字体加粗等。

    注:使用CSS样式的一个好处是通过定义某个样式,可以让不同网页位置的文字有着统一的字体、字号或者颜色等。

2、css语法

    css 样式由选择符和声明组成,而声明又由属性和值组成,如下图所示:

      css语法和基本知识

    

    选择符:又称选择器,指明网页中要应用样式规则的元素,如本例中是网页中所有的段(p)的文字将变成蓝色,而其他的元素(如ol)不会受到影响。

    声明:在英文大括号“{}”中的的就是声明,属性和值之间用英文冒号“:”分隔。当有多条声明时,中间可以英文分号“;”分隔,如下所示:

      p{font-size:12px;color:red;}

    注意:

      1、最后一条声明可以没有分号,但是为了以后修改方便,一般也加上分号。

      2、为了使用样式更加容易阅读,可以将每条代码写在一个新行内,如下所示:

        p{
       font-size:12px;
        color:red;
      }

 3、CSS样式

    CSS样式一共有三种:内联式、嵌入式和外部式。

    (1)内联式:把CSS代码直接写在HTML标签中,并且要写在style=""中,如有多条CSS样式,可以写在一起,以分号隔开,最后一条样式可以不用分号,但可以写上,方便后面加上其它CSS样式。

      <span style="font-size:12px;color:blue";>内联式</span>

    

    (2)嵌入式:把CSS代码写在<style type="text/css"></style>标签之间,嵌入式css样式必须写在<style></style>之间,并且一般情况下嵌入式css样式写在<head></head>之间。

      <style type="text/css">
        span{
          color:red;
        }
     </style>

    (3)外部式:把CSS代码写一个单独的外部文件中,这个css样式文件以“.css”为扩展名,在<head>内(不是在<style>标签内)使用<link>标签将css样式文件链接到HTML文件内。

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

    注:三种CSS样式写法的优先级,内联式>嵌入式>外部式,但是嵌入式>外部式有一个前提:嵌入式css样式的位置一定在外部式的后面。其实总结来说,就是就近原则(离被设置元素越近优先级别越高)。但注意上面所总结的优先级是有一个前提:内联式、嵌入式、外部式样式表中css样式是在的相同权值的情况下,什么是权值呢?后面会讲。
    三种样式如下:

      <!DOCTYPE HTML>
      <html>
      <head>
      <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
      <!--外部式-->
      <link href="style.css" rel="stylesheet" type="text/css">

      <-- 嵌入式css样式 -->
      <style type="text/css">
        span{
          color:red;
        }
      </style>
      </head>
      <body>

        <!--  内联式 -->
        <span style="color:pink">超酷的互联网</span>
      </body>
      </html>

 4、选择器

    CSS样式声明由两部分组成,“选择器”指明了{}中的“样式”的作用对象,也就是“样式”作用于网页中的哪些元素。

      选择器{

        样式;

      }

    (1)标签选择器:标签选择器其实就是html代码中的标签。如右侧代码编辑器中的<html>、<body>、<h1>、<p>、<img>。   

      <style type="text/css">
        h1{
          color:red;
        font-weight:normal;
      }

      </style>

      <h1>标签选择器</h1>

    (2)类选择器:通过标签的class属性的值来设置标签的CSS样式。

      <style type="text/css">

        .spans{

          color:red;

        }

      </style>

      <span class="spans">类选择器</span>

    (3)ID选择器:通过标签的id属性的值设置标签的CSS样式。

      <style type="text/css">

        #spans{

          color:red;

        }

      </style>

      <span id="spans">ID选择器</span>

    (4)后代选择器:标签A中包含B标签,那么A就是B标签的父元素,B就是A标签的子元素,一个标签可以有多个子元素。如果存在多个class相同的元素,但是只想修改指定的class元素的样式,可以使用后代选择器。使用后代选择器可以更加精确的定位元素

      

      <style type="text/css">
      .father .son1{
        color: red;
      }

      .son1{

        color: blue;

      }

      <p class="father">后代选择器
        <span class="son1">子元素1</span>

        <span class="son2">子元素2</span>
      </p>
      <span class="son1">子元素3</span>

        css语法和基本知识

      注:实验发现后面设置.son1的样式并不会影响到前面后代选择器写法中class = .son1的元素,至于为什么,还不知道原因。

    (5)子选择器:根据父元素的ID或者class的值来设置第一代子元素的样式。写法如下:

      .father > li{    <!-- 如果是Id选择器,.father改为#father-->
        color: red;
      }

      <ul class="father" id="father">
        <li>儿子1</li>

        <li>儿子2</li>
        <ul>
          <li>孙子</li>
        </ul>
      </ul>

        css语法和基本知识

    注:子选择器仅是指它的直接后代,或者你可以理解为作用于子元素的第一代后代。而后代选择器是作用于所有子后代元素。后代选择器通过空格来进行选择,而子选择器是通过“>”进行选择。

    (6)通用选择器:它是功能最强大的一个选择器,用*号来指定,它的作用是匹配html中的所有标签元素。

    (7)伪类选择器:它允许给html不存在的标签设置样式,比如说鼠标滑过一个标签时,显示的样式。如下面的a标签,当鼠标滑过时,a标签的颜色就会变成红色:

      a:hover{

        color: red;

      }

    (8)分组选择器:当你想要为多个标签设置同一个样式时,可以使用分组选择器,不同标签之间用,隔开。如下:

      h1, h2, h3{

        color: red;

        font-size: 20px;

      }

      

      <h1>分组选择器1</h1>
      <h2>分组选择器2</h2>
      <h3>分组选择器3</h3>
      <h4>分组选择器4</h4>

        css语法和基本知识

5、CSS的继承、特殊性和层叠

    (1)继承:一个标签A里面包含其他标签BC,那么A标签的后代就是BC标签,A标签具有的一些属性是可以被BC标签继承的,有些属性是不可以的,详情请看:https://www.cnblogs.com/thislbq/p/5882105.html

  

    (2)选择器的特殊性:当多个样式规则作用于同一个元素中时,究竟哪个样式会生效呢?这要取决于特殊性的高低。标签选择器的权值为1,类选择器的权值为10,ID选择器的权值为100,例子:

判断class="one"的元素最后显示的是什么颜色?

      #one{
        color: blue;
      }
      li{
        color: red;
      }
      .one{
        color: green;
      }

   

      <ul>
        <li class="one" id="one">1</li>
        <li>2</li>
        <li>3</li>
      </ul>

      显然,ID选择器的权值更高,所以显示的是蓝色。

    

    (3)层叠:在html文件中对于同一个元素可以有多个css样式存在,当有相同权重的样式存在时,会根据这些css样式的前后顺序来决定,处于最后面的css样式会被应用。内联样式表(标签内部)> 嵌入样式表(当前文件中)> 外部样式表(外部文件中)。(嵌入样式>外部样式的条件是,嵌入样式在外部样式之后)

    (4)重要性:重要性(!import),来表示样式的最高权值。

      语法例子:<p style="color: blue!import;">

6、颜色值

    设置颜色的方法:

    (1)用英文

      p{color: red;}

    (2)用RGB颜色值

      p{color:rgb(113,145,300);}

    (3)用十六进制颜色

      p{color:rgb(22%,31%,22%);}
7、长度值
    目前比较常用到px(像素)、em、% 百分比,要注意其实这三种单位都是相对单位。
    (1)像素:像素为什么是相对单位呢?因为像素指的是显示器上的小点(CSS规范中假设“90像素=1英寸”)。实际情况是浏览器会使用显示器的实际像素值有关,在目前大多数的设计者都倾向于使用像素(px)作为单位。
    (2)em:就是本元素给定字体的 font-size 值,如果元素的 font-size 为 14px ,那么 1em = 14px;如果 font-size 为 18px,那么 1em = 18px。如下代码:
      p{font-size:12px;text-indent:2em;}
    注:但当给 font-size 设置单位为 em 时,此时计算的标准以 p 的父元素的 font-size 为基础。如下代码:
    (3)百分比
      p{font-size:12px;line-height:130%}

      设置行高(行间距)为字体的130%(12 * 1.3 = 15.6px)。

上一篇:java数据类型和运算优先级


下一篇:wpf 获取DataGrid某一个单元格,设置此单元格ToolTip内容和背景颜色