zoukankan      html  css  js  c++  java
  • css语法和基本知识

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

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

    2、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>

            

          注:实验发现后面设置.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>

            

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

        (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>

            

    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)。

  • 相关阅读:
    工厂模式 ioc dom4j 反射之我的一点理解
    hibernate中注解方式中的控制反转
    java中的数据存储(堆,栈) 很重要
    hibernate中映射关系总结
    三极管使用方法
    OC OD介绍
    HP Jack介绍
    Jlink接口的Jtag和SWD接口定义
    什么是域什么是工作组
    Ubuntu安装.run文件
  • 原文地址:https://www.cnblogs.com/siyuhuang/p/10067546.html
Copyright © 2011-2022 走看看