zoukankan      html  css  js  c++  java
  • CSS3基础知识

    CSS3基础

    1 样式表的使用

    1.内联样式表。

    只影响单个元素,常用于标签。

    <p style="color: aqua;font-size: 20px">This is CSS.</p>

    2.内部样式表。

    对本页面元素起作用,一般写在<head></head>中,用<style></style>定义。

    <head>

    <meta charset="utf-8">

    <title>无标题文档</title>

    <style>

           body{

                  font-family: "宋体";

           }

           </style>

    </head>

    3.连接外部样式表。

    建立一个外部CSS文件用link元素引入到HTML中。

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

    总结:

    CSS内联:就是把CSS放在HTML Head里使用Style包围。<style type="text/css"></style>

    CSS外联:就是把CSS放到一个单独的文件里,然后在HTML通过调用。<link rel="stylesheet" type="text/css" href="">。

    我们知道HTTP请求是比较昂贵的,CSS内联的话肯定会更快,因为把CSS放到HTML文件里,这意味着减少了一次HTTP请求。而外联的话就是 一次HTTP请求,但是可以缓存,当浏览器加载过这个文件时,第二次请求的时候是第缓存里读取的,所以第二次请求时是很快的,外联的CSS还可以重用代 码。那到底是使用内联还是外联呢?这就要看需求,如果一个页面不需要缓存时,也就是这个页面不太访问,或者访问不多的时候,比如注册页面,一般情况下人家 只会进入一次,不可能第次进入这个网站你都去注册,那就另当别论了,这个页面不需要缓存,把CSS放在Head里时可以缩短加载时间,提高用户体验。对于 经常访问的页面,外联肯定是不二的选择。

    在一些大的网站,如:Google,Yahoo也可以看到把CSS写在Head里。对于结构表现行为分离的原则,我们对于CSS入在Head里是可以接受的,只要不是写在元素上面。

    Copyright@Kingwell Leng

    2 定义选择器

    选择器分两个种类,第一种为DOM选择器,包含类型选择器、类选择器和选择元素一部分和ID选择器,第二种包含伪选择器。

    1.按照类型选择元素。

           以标签为单位来设置相同的显示样式,不需要定义前缀符。

    <style>

           p{

                  font-family: "宋体";color: red;

           }

           a{color: #ADADAD;}

           </style>

    2.按照类型选择标签。

           以标签样式类型选择为选择条件,类型为class,“.”为前缀,可以对多个标签应用样式,也可以派生样式。

    <head>

    <style type=”text/css”>

           .anyname{

                  font-family: "宋体";

                  color: #ADADAD;

                  100px;

                  height: auto;

                  border: 1px solid blue;

           }

           </style>

    </head>

    <body>

           <p>This is CSS.</p>

           <div class="anyname">

                  <p>This is CSS!</p>

           </div>

    </body>

    3.按照ID选择元素

           类似与类型选择器,以“#”为前缀,在标签中加入id属性引用样式。

    <head>

    <style type="text/css">

           #box{

                  font-family: "宋体";

                  color: #ADADAD;

                  100px;

                  height: auto;

                  border: 1px solid blue;

           }

           </style>

    </head>

    <body>

           <p>This is CSS.</p>

           <div id="box">

                  <p>This is CSS!</p>

           </div>

    </body>

    4.选择元素的一部分

           单独选择元素从而不影响其他元素,有子元素选择器和多重元素选择器。

    1)子元素选择器

    h1>strong{color:red;}

    或者:h1 strong{color:red;}

    注:只对第一层有效

    2)多重元素选择器

           优点在于避免过多的id、class属性设置,直接对所需元素进行定义。

    #anyname p li a{float:right;  color:#ADADAD;}

    3)选择部分元素

           实现多个元素或标签设置为同一样式。

    <style type="text/css">

    html {color:black;}

    p {color:blue;}

    h2 {color:silver;}

    </style>

          

    5. 伪类选择器

           CSS中已经定义好的选择器,不可以重命名。

    1)<a>标签中的集中选择器

          

           a:link表示未访问的链接

    a:visited表示已访问的链接

    a:hover表示鼠标悬停的链接

    a:active表示选定的链接(被按下时)

    注:在 CSS 定义中,a:hover 必须被置于 a:link 和 a:visited 之后,才是有效的。

    在 CSS 定义中,a:active 必须被置于 a:hover 之后,才是有效的。

    如:a:link{color:#ADADAD;text-decoration:none;}/*none表示将默认下划线去掉*/

    2)CSS中四个伪元素选择器

           First-line       对所选标签元素的第一行应用样式   p:first-line{color:red;}

           First-letter     对所选标签元素的文字首字母应用样式   p:first-letter{color:bule;}

           Before           在某个元素前插入一些内容      li:before{content:”^^^”;}

    After              在某个元素后插入一些内容      li:after{content:”(仅用于测试)”;}

    3 文本与排版样式的使用

    1. 长度、百分单位

           像素(px)与百分比是常用的长度单位。

    在没有CSS规则限制下,长度关系:1em(相对单位)==16px(像素)==0.17in(英寸)==12pt(点)==1pc(派卡)==4.2mm(毫米)==0.42cm(厘米)

    2. 文本样式属性

    1) text-shadow 文字阴影。

           div {

                  text-shadow: 10px 10px 10px orange,/*x偏移量,y偏移量,模糊半径,颜色*/

                                       40px 40px 40px yellow,

                                       20px 20px 23px #ADADAD;/*设置多个文字阴影*/

                  font-size: 50px;

                  font-weight: bold;/*{normal|bold|bolder|lighter|inherit}*/

                  font-family: "宋体";

                  color: navy;

           }

    2) word-wrap 文本的控制换行。用于指定区域如div显示不完一行文字的时候为了不超出区域范围而使用的强制换行。

           Word-wrap; normal  | break-word

           *normal 只能在两个单词之间折断,break-word允许词内换行

    3) webfont与font-face CSS3中webfont功能使网页上能显示服务器端的字体。

           使用方法:直接在<style></style>中插入以下代码

    @font-face{

                  font-famliy:WebFont;

                  src: url('Font_Sans_R_45b.otf')format("opentype");/*应用服务器端字体*/

                  font-weight: normal;

           }

    4) font-size-adjust 可以保持字体在大小部发生变化的情况下改变字体的类型。

    font-size-adjust: 0.46;

    5) text-ouline与text-stroke 轮廓控制属性。

    Text-outline: 2px 4px red;   /*宽度,模糊半径,颜色*/

          

           Text-stroke   描边控制

    -webkit-text-stroke:3px #ADADAD;         /*宽度,颜色*/

    4 背景和颜色的使用

    1. 背景颜色

           网页背景颜色设置:Background-color: transparent | color /*透明或者设置颜色*/

           HSLA:/*色调(0-360,0&360==red,120==green,240==bule),饱和度(100%),亮度(100%),透明度(0~1)*/

                  div.a{background:hsla(120,35%,50%,0.2);height: 20px;}

    2. 背景图片

           格式如下:

                  Body{background-img:url(../picture.jpg);}

    关于background还有一些属性如-cilp、origin、size等控制背景图片位置等属性

    5 盒子概念与使用

    1. 元素外边界。

           外边界定义了矩形对象与其他矩形对象的距离,即模块与模块之间的空隙。

    margin-bottom: 10px;/*下边界*/

                  margin-left: 20px;/*左边界*/

    padding: 40px 30px 20px 60px;/*上下左右边界*/

                  margin: 0 auto;/*auto居中*/

    2. 元素边框

           可以定义边框粗细。

    border: 50px #ADADAD;/*定义粗细,颜色*/

                  border-style: solid dotted double dashed;/*上下左右边框单独设置样式*/

    border-style属性:none|hidden|dotted|dashed|solid|double|groove|ridge|inset|outset|inherit

    3. 元素内边界

           内容与边框的空隙,与外边界属性类似。

                  padding: 40px;

    设置一个的时候表示上下左右距离一样,也可以用分别设置上下左右边界距离。

                  padding: 40px 30px 20px 60px;

    4. 内容的宽度、高度设置

           在设置边框的时候可以一同定义内容的宽高度。

    div.a{

                  background:hsla(120,35%,50%,0.2);height: 20px;200px;

                  margin-bottom: 10px;/*外边界定义*/

                  margin-left: 20px;

                  margin: 0 auto;

                  padding: 40px 30px 20px 60px;/*内边界定义*/

                  height: 100px;/*宽高度定义*/

                  100px;

                  border: 50px #ADADAD;/*边框定义*/

                  border-style: solid dotted double dashed;

           }

    5. 列表样式

    常见的列表属性值

           list-style-type /*设定引导列表的符号类型*/

           list-style-image /*选择图像作为项目的引导符号*/

           list-style-position /*决定列表项目缩进*/

           常见的列表符号属性

                  Circle                   设定类型

                  Square                 图像

                  Decimal                阿拉伯数字

                  Lower-roman       小写罗马数字

                  Wpper-roman      大写罗马数字

                  Lower-alpha         小写字母

                  Wpper-alpha       大写字母

                  None                    不现实项目符号

                  Disc                      实心圆

           在style中使用列表样式

                  List-style-type:decimal;

    注:

    //-ms代表ie内核识别码
    //-moz代表火狐内核识别码
    //-webkit代表谷歌内核识别码
    //-o代表欧朋【opera】内核识别码
    //统标识语句句写符合w3c标准

     2017-11-15

  • 相关阅读:
    架构师的成长之路初片~LVS+keepalived---- and-----haproxy
    架构师的成长之路初片~LVS
    架构师的成长之路初片~iptables-下
    架构师的成长之路初片~iptables-上
    架构师的成长之路初片~Linux基本防护措施
    架构师的成长之路初片~kill扫描
    架构师的成长之路初片~自动化篇之Ansible
    架构师的成长之路初片~部署简单git
    架构师的成长之路初片~源码包服务(nginx)实现systemctl控制服务
    XML序列化、反序列化
  • 原文地址:https://www.cnblogs.com/tianyanzhi/p/7839654.html
Copyright © 2011-2022 走看看