整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          CSS是什么?這一篇全解,絕對有你想要的

          CSS 是什么?

          CSS是Cascading Style Sheets的簡稱,中文稱為層疊樣式表。

          屬性和屬性值用冒號隔開,以分號結尾。

          CSS 四種引入方式:

          1.行內式

          行內式是在標簽的style屬性中設定CSS樣式。

          <div style="..."></div>

          2.嵌入式

          嵌入式是將CSS樣式集中寫在網頁的<head>標簽的<style></style>標簽對中。

          <head>
          
              ...
          
              <style type="text/css">
          
                  ...此處寫CSS樣式
          
              </style>
          
          </head>

          3.導入式
          將一個獨立的.css文件引入HTML文件中,導入式使用@import 引入外部CSS文件,<style>標記也是寫在<head>標記中。

          導入式會在整個網頁裝載完后再裝載CSS文件。

          <head>
          
              ...
          
              <style type="text/css">
          
                  @import "My.css"; 此處注意.css文件的路徑
          
              </style>
          
          </head>

          4.鏈接式
          將一個獨立的.css文件引入到HTML文件中,使用<link>標記寫在<head>標記中。

          鏈接式會以網頁文件主體裝載前裝載CSS文件。

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

          樣式應用順序:

          • 行內樣式優先級最高
          • 針對相同的樣式屬性,不同的樣式屬性將以合并的方式呈現
          • 相同樣式并且相同屬性,呈現方式在<head>中的順序決定,后面會覆蓋前面屬性
          • !important 指定樣式規則應用最優先
          .nick {
              color: yellow !important;
          }

          選擇器(Selector)

          基本選擇器:

          1.通用元素選擇器

          * 表示應用到所有的標簽。

          * {color: yellow}

          2.標簽選擇器

          匹配所有使用 div 標簽的元素(可以匹配所有標簽)

          div {color: yellow}

          3.類選擇器

          匹配所有class屬性中包含info的元素。

          語法:.類名{樣式}(類名不能以數字開頭,類名要區分大小寫。)

          .Mycolor {color: yellow}
          <h3 class="Mycolor">nick</h3>

          4.ID選擇器

          使用id屬性來調用樣式,在一個網頁中id的值都是唯一的(是W3C規范而不是規則,所以不會報錯)。

          語法:#ID名{樣式}(ID名不能以數字開頭)

          #Mycolor {color: yellow}
          <h3 id="Mycolor">Nick.</h3>

          組合選擇器:

          1.多元素選擇器

          同時匹配h3,h4標簽,之間用逗號分隔。

          h3,h4 {color: yellow;}
          <h3>Nick</h3>
          <h4>Jenny</h4>
          

          2.后代元素選擇器

          匹配所有div標簽里嵌套的P標簽,之間用空格分隔。

              div p {color: yellow;}
          <div>
              <p>Nick</p>
              <div>
                  <p>Nick</p>
              </div>
          </div>

          3.子元素選擇器

          匹配所有div標簽里嵌套的子P標簽,之間用>分隔。

              div > p {color: yellow;}
          <div>
              <p>Nick</p>
              <p>Nick</p>
          </div>

          4.毗鄰元素選擇器

          匹配所有緊隨div標簽之后的同級標簽P,之間用+分隔(只能匹配一個)。

              div + p {color: yellow;}
          <div>Nick</div>
          <p>Nick</p>

          屬性選擇器:

          1.[title] & P[title]

          設置所有具有title屬性的標簽元素;

          設置所有具有title屬性的P標簽元素。

              [title]
              {
                  color: yellow;
              }
              p[title]
              {
                  color: yellow;
              }
           
          <div title>Nick</div>
          <p title>Nick</p>

          2.[title=Nick]

          設置所有title屬性等于“Nick”的標簽元素。

              [title="Nick"]
              {
                  color: yellow;
              }
          <p title="Nick">Nick</p>

          3.[title~=Nick]

          設置所有title屬性具有多個空格分隔的值、其中一個值等于“Nick”的標簽元素。

              [title~="Nick"]
              {
                  color: yellow;
              }
          <p title="Nick Jenny">Nick</p>
          <p title="Jenny Nick">Nick</p>

          4.[title|=Nick]

          設置所有title屬性具有多個連字號分隔(hyphen-separated)的值、其中一個值以"Nick"開頭的標簽元素。

          例:lang屬性:"en"、"en-us"、"en-gb"等等

              [title|="Nick"]
              {
                  color: yellow;
              }
           <p title="Nick-Jenny">Nick</p>
          

          5.[title^=Nick]

          設置屬性值以指定值開頭的每個標簽元素。

              [title^="Nick"]
              {
                  color: yellow;
              }
          <p title="NickJenny">Nick</p>

          6.[title$=Nick]

          設置屬性值以指定值結尾的每個標簽元素。

              [title$="Nick"]
              {
                  color: yellow;
              }
          <p title="JennyNick">Nick</p>

          7.[title*=Nick]

          設置屬性值中包含指定值的每個元素

          [title*="Nick"]
              {
                  color: yellow;
              }
           
          <p title="SNickJenny">Nick</p>

          偽類選擇器:

          1. link、hover、active、visited

          • a:link(未訪問的鏈接狀態),用于定義了常規的鏈接狀態。
          • a:hover(鼠標放在鏈接上的狀態),用于產生視覺效果。
          • a:active(在鏈接上按下鼠標時的狀態)。
          • a:visited(已訪問過的鏈接狀態),可以看出已經訪問過的鏈接。
              a:link{color: black}
              a:hover{color: yellow}
              a:active{color: blue}
              a:visited{color: red} 
          <a href="#">Nick</a>

          2. before、after

          • P:before 在每個<p>元素的內容之前插入內容;
          • P:after 在每個<p>元素的內容之后插入內容。
              p {
                  color: yellow;
              }
              p:before{
                  content: "before...";
              }
              p:after{
                  content: "after...";
              }
           <p> Nick </p>  

          常用屬性

          1. 顏色屬性:

          color

          • HEX(十六進制色:color: #FFFF00 --> 縮寫:#FF0)
          • RGB(紅綠藍,使用方式:color:rgb(255,255,0)或者color:rgb(100%,100%,0%))
          • RGBA(紅綠藍透明度,A是透明度在0~1之間取值。使用方式:color:rgba(255,255,0,0.5))
          • HSL(CSS3有效,H表示色調,S表示飽和度,L表示亮度,使用方式:color:hsl(360,100%,50%))
          • HSLA(和HSL相似,A表示Alpha透明度,取值0~1之間。)

          transparent

          • 全透明,使用方式:color: transparent;

          opacity

          • 元素的透明度,語法:opacity: 0.5;
          • 屬性值在0.0到1.0范圍內,0表示透明,1表示不透明。
          • filter濾鏡屬性(只適用于早期的IE瀏覽器,語法:filter:alpha(opacity:20);)。

          2. 字體屬性:

          font-style: 用于規定斜體文本

          • normal 文本正常顯示
          • italic 文本斜體顯示
          • oblique 文本傾斜顯示

          font-weight: 設置文本的粗細

          • normal(默認)
          • bold(加粗)
          • bolder(相當于<strong>和<b>標簽)
          • lighter (常規)
          • 100 ~ 900 整百(400=normal,700=bold)

          font-size: 設置字體的大小

          • 默認值:medium
          • <absolute-size>可選參數值:xx-small、 x-small、 small、 medium、 large、 x-large、 xx-large
          • <relative-size>相對于父標簽中字體的尺寸進行調節。可選參數值:smaller、 larger
          • <percentage>百分比指定文字大小。
          • <length>用長度值指定文字大小,不允許負值。

          font-family:字體名稱

          • 使用逗號隔開多種字體(優先級從前向后,如果系統中沒有找到當前字體,則往后面尋找)

          font:簡寫屬性

          • 語法:font:字體大小/行高 字體;(字體要在最后)

          3. 文本屬性:

          white-space: 設置元素中空白的處理方式

          • normal:默認處理方式。
          • pre:保留空格,當文字超出邊界時不換行
          • nowrap:不保留空格,強制在同一行內顯示所有文本,直到文本結束或者碰到br標簽
          • pre-wrap:保留空格,當文字碰到邊界時換行
          • pre-line:不保留空格,保留文字的換行,當文字碰到邊界時換行

          direction: 規定文本的方向

          • ltr 默認,文本方向從左到右。
          • rtl 文本方向從右到左。

          text-align: 文本的水平對齊方式

          • left
          • center
          • right

          line-height: 文本行高

          • normal 默認

          vertical-align: 文本所在行高的垂直對齊方式

          • baseline 默認
          • sub 垂直對齊文本的下標,和<sub>標簽一樣的效果
          • super 垂直對齊文本的上標,和<sup>標簽一樣的效果
          • top 對象的頂端與所在容器的頂端對齊
          • text-top 對象的頂端與所在行文字頂端對齊
          • middle 元素對象基于基線垂直對齊
          • bottom 對象的底端與所在行的文字底部對齊
          • text-bottom 對象的底端與所在行文字的底端對齊

          text-indent: 文本縮進

          letter-spacing: 添加字母之間的空白

          word-spacing: 添加每個單詞之間的空白

          text-transform: 屬性控制文本的大小寫

          • capitalize 文本中的每個單詞以大寫字母開頭。
          • uppercase 定義僅有大寫字母。
          • lowercase 定義僅有小寫字母。

          text-overflow: 文本溢出樣式

          • clip 修剪文本。
          • ellipsis 顯示省略符號...來代表被修剪的文本。
          • string 使用給定的字符串來代表被修剪的文本。
          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Title</title>
              <!--<link href="cc2.css" rel="stylesheet" type="text/css">-->
              <style>
                  div {
                      width: 100px;
                      height: 100px;
                      white-space: nowrap;
                      overflow: hidden;
                      text-overflow: ellipsis;
                  }
              </style>
          </head>
          <body>
              <div>索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧 索寧</div>
          </body>
          </html>

          text-decoration: 文本的裝飾

          • none 默認。
          • underline 下劃線。
          • overline 上劃線。
          • line-through 中線。

          text-shadow:文本陰影

          • 第一個參數是左右位置
          • 第二個參數是上下位置
          • 第三個參數是虛化效果
          • 第四個參數是顏色
          • text-shadow: 5px 5px 5px #888;

          word-wrap:自動換行

          • word-wrap: break-word;
          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Title</title>
              <style>
                  p {
                      width: 150px;
                      height: 160px;
                      background-color: #FFA500;
                      /*邊框陰影*/
                      box-shadow: 10px 10px 5px #888;
                      /*自動換行*/
                      word-wrap: break-word;
                  }
                  h1 {
                      text-shadow: 5px 5px 5px #888;
                  }
              </style>
          </head>
          <body>
              <p>
                  When you are old and grey and full of sleep,And nodding by the fire, take down this book,And slowly read, and dream of the soft look
              </p>
              <h1>索寧</h1>
          </body>
          </html>    

          a {
              text-decoration: none;
              /*去除a標簽下劃線*/
          }

          4. 背景屬性

          background-color: 背景顏色

          background-image 設置圖像為背景

          • url("http://images.cnblogs.com/cnblogs_com/suoning/845162/o_ns.png"); 圖片地址
          • background-image:linear-gradient(green,blue,yellow,red,black); 顏色漸變效果

          background-position 設置背景圖像的位置坐標

          • background-position: center center; 圖片置中,x軸center,y軸center
          • 1px -195px 截取圖片某部分,分別代表坐標x,y軸

          background-repeat 設置背景圖像不重復平鋪

          • no-repeat 設置圖像不重復,常用
          • round 自動縮放直到適應并填充滿整個容器
          • space 以相同的間距平鋪且填充滿整個容器

          background-attachment 背景圖像是否固定或者隨著頁面的其余部分滾動

          background 簡寫

          • background: url("o_ns.png") no-repeat 0 -196px;
          • background: url("o_ns.png") no-repeat center bottom 15px;
          • background: url("o_ns.png") no-repeat left 30px bottom 15px;

          5. 列表屬性

          list-style-type: 列表項標志的類型

          • none 去除標志
          • decimal-leading-zero; 02.
          • square; 方框
          • circle; 空心圓
          • upper-alph; & disc; 實心圓

          list-style-image:將圖象設置為列表項標志

          list-style-position:列表項標志的位置

          • inside
          • outside

          list-style:縮寫

          頁面布局

          1. 邊框

          border-style:邊框樣式

          • solid 默認,實線
          • double 雙線
          • dotted 點狀線條
          • dashed 虛線

          border-color:邊框顏色

          border-width:邊框寬度

          border-radius:圓角

          • 1個參數:四個角度應用
          • 2個參數:第一個參數應用于 左上、右下;第二個參數應用于 左下、右上
          • 3個參數:第一個參數應用于 左上;第二個參數應用于 左下、右上;第三個參數應用于右下
          • 4個參數:左上、右上、右下、左下(順時針)

          border: 簡寫

          • border: 2px yellow solid;

          box-shadow:邊框陰影

          • 第一個參數是左右位置
          • 第二個參數是上下位置
          • 第三個參數是虛化效果
          • 第四個參數是顏色
          • box-shadow: 10px 10px 5px #888;
          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Title</title>
              <style>
                  div {
                      border:2px solid;
                      border-radius:25px;
                      width: 140px;
                  }
              </style>
          </head>
          <body>
              <div>
                   點贊哦!dear. 
              </div>
          </body>
          </html>

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Title</title>
              <style>
                  .radius1 {
                      display: inline-block;
                      width: 100px;
                      height: 100px;
                      background-color: yellow;
                      border-radius: 20px;
                  }
                  .radius2 {
                      display: inline-block;
                      width: 100px;
                      height: 100px;
                      background-color: red;
                      border-radius: 20px 35px;
                  }
                  .radius3 {
                      display: inline-block;
                      width: 100px;
                      height: 100px;
                      background-color: blue;
                      border-radius: 20px 35px 50px;
                  }
                  .radius4 {
                      display: inline-block;
                      width: 100px;
                      height: 100px;
                      background-color: green;
                      border-radius: 20px 35px 50px 60px;
                  }
              </style>
          </head>
          <body>
              <div>
                  <span class="radius1"></span>
                  <span class="radius2"></span>
                  <span class="radius3"></span>
                  <span class="radius4"></span>
              </div>
          </body>
          </html>

          邊框實現各種三角符號:

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Title</title>
              <style>
                  .triangle-one {
                      display: inline-block;
                      border-top: 50px red solid;
                      border-right: 50px green solid;
                      border-bottom: 50px yellow solid;
                      border-left: 50px blue solid;
                  }
                  .triangle-two {
                      display: inline-block;
                      border-top: 0 red solid;
                      border-right: 50px green solid;
                      border-bottom: 50px yellow solid;
                      border-left: 50px blue solid;
                  }
                  .triangle-stree {
                      display: inline-block;
                      border-top: 50px red solid;
                      border-right: 0 green solid;
                      border-bottom: 50px yellow solid;
                      border-left: 50px blue solid;
                  }
                  .triangle-four {
                      display: inline-block;
                      border-top: 50px red solid;
                      border-right: 0 green solid;
                      border-bottom: 0 yellow solid;
                      border-left: 50px blue solid;
                  }
           
                  .triangle-five {
                      display: inline-block;
                      border: 50px transparent solid;
                      border-top: 50px red solid;
                  }
                  .triangle-six {
                      display: inline-block;
                      border: 50px transparent solid;
                      border-bottom: 50px yellow solid;
                  }
                  .triangle-seven {
                      display: inline-block;
                      border: 50px transparent solid;
                      border-top: 60px red solid;
                      border-right: 0;
                  }
                  .triangle-eight {
                      display: inline-block;
                      border: 50px transparent solid;
                      border-left: 30px yellow solid;
                      border-bottom: 0;
                  }
              </style>
          </head>
          <body>
              <div class="triangle-one"></div>
              <div class="triangle-two"></div>
              <div class="triangle-stree"></div>
              <div class="triangle-four"></div>
              <div class="triangle-five"></div>
              <div class="triangle-six"></div>
              <div class="triangle-seven"></div>
              <div class="triangle-eight"></div>
          </body>
          </html>

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Title</title>
              <style>
                  .back {
                      width: 1000px;
                      height: 1000px;
                      margin: 0 auto;
                      background-color: #ddd;
                      position: relative;
                  }
                  .back-in {
                      position: absolute;
                      width: 1020px;
                      height: 45px;
                      left: -20px;
                      top: 50px;
                      background-color: #2F4F4F;
                  }
                  .back-img {
                      border: 20px solid transparent;
                      border-top: 10px solid dimgrey;
                      border-right: 0;
                      display: inline-block;
                      position: absolute;
                      top: 95px;
                      left: -20px;
                  }
                  .back-font {
                      line-height: 9px;
                      margin-left: 30px;
                      color: white;
                  }
              </style>
          </head>
          <body>
              <div class="back">
                  <div class="back-in"><h3 class="back-font">妹子求關注 ^.^</h3></div>
                  <div class="back-img"></div>
              </div>
          </body>
          </html>

          2.★ 盒子模型

          一個標準的盒子模型:

          padding:用于控制內容與邊框之間的距離;

          margin: 用于控制元素與元素之間的距離;

          一個參數,應用于四邊。

            兩個參數,第一個用于上、下,第二個用于左、右。

            三個參數,第一個用于上,第二個用于左、右,第三個用于下。

          邊框在默認情況下會定位于瀏覽器窗口的左上角,但是并沒有緊貼著瀏覽器的窗口的邊框,這是因為body本身也是一個盒子,外層還有html,
          在默認情況下,body距離html會有若干像素的margin,所以body中的盒子不會緊貼瀏覽器窗口的邊框了。
          
          解決方法:
          body {
              margin: 0;
          }

          3.★ display

          • none 不顯示。
          • block 顯示為塊級元素。
          • inline 顯示為內聯元素。
          • inline-block 行內塊元素(會保持塊元素的高寬)。
          • list-item 顯示為列表元素。

          4. visibility

          • visible 元素可見
          • hidden 元素不可見
          • collapse 當在表格元素中使用時,此值可刪除一行或一列,不會影響表格的布局。

          5.★ float 浮動

          讓一行顯示兩個塊級標簽,會脫離文檔流

          • none
          • left 左浮動
          • right 右浮動

          clear 清除浮動:

          • none : 默認值。允許兩邊都可以有浮動對象
          • left : 不允許左邊有浮動對象
          • right : 不允許右邊有浮動對象
          • both : 不允許兩邊有浮動對象

          6. clip 剪裁圖像

          rect 剪裁定位元素:

          • auto 默認值,無剪切
          • 上-右-下-左(順時針)的順序提供四個偏移值
          • 區域外的部分是透明的
          • 必須指定 position:absolute;
          • 例:clip:rect(0px,60px,200px,0px);

          7. overflow 設置當對象的內容超過其指定高度及寬度時如何顯示內容

          • visible 默認值,內容不會被修剪,會呈現在元素框之外。
          • hidden 內容會被修剪,并且其余內容是不可見的。
          • scroll 內容會被修剪,但是瀏覽器會顯示滾動條以便查看其余的內容。
          • auto 如果內容被修剪,則瀏覽器會顯示滾動條以便查看其余的內容。

          8.★ position 規定元素的定位類型

          • 通過以下四種屬性進行定位:
          • left
          • top
          • right
          • bottom
          • z-index

          9. z-index 元素層疊順序

          • z-index 僅在定位元素上有效(例:position:absolute;)
          • 可以指定負數屬性值(例:-1;)
          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Title</title>
              <style>
                  .z-index1 {
                      width: 100px;
                      height: 100px;
                      background-color: yellow;
                      position: absolute;
                      z-index: -1;
                  }
                  .z-index2 {
                      width: 100px;
                      height: 100px;
                      background-color: red;
                      position: absolute;
                      top: 20px;
                      left: 20px;
                      z-index: 5;
                  }
              </style>
          </head>
          <body>
              <div class="z-index1"></div>
              <div class="z-index2"></div>
          </body>
          </html>

          10. outline 邊框輪廓

          • outline-width 輪廓寬度
          • outline-color 輪廓顏色
          • outline-style 輪廓樣式

          11. zoom 縮放比例

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Title</title>
              <style>
                  .zoom1 {
                      zoom: 100%;
                  }
                  .zoom2 {
                      zoom: 150%;
                  }
                  .zoom3 {
                      zoom: 200%;
                  }
              </style>
          </head>
          <body>
              <div class="zoom1">Nick 100%</div>
              <div class="zoom2">Nick 200%</div>
              <div class="zoom3">Nick 300%</div>
          </body>
          </html>

          12. cursor 鼠標的類型形狀

          鼠標放在以下單詞上,There will be a miracle:

          url: 自定義光標

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Title</title>
              <!--<link href="cc2.css" rel="stylesheet" type="text/css">-->
              <style>
                  body {
                      cursor: url("mouse.png"), auto;
                      /*圖片地址:http://images.cnblogs.com/cnblogs_com/suoning/845162/o_mouse.png*/
                  }
              </style>
          </head>
          <body>
              <div><img src="http://images.cnblogs.com/cnblogs_com/suoning/845162/o_ns.png" height="100%" width="100%"></div>
          </body>
          </html>

          Auto: 默認
          Default: 默認
          e-resize
          ne-resize
          nw-resize
          n-resize
          se-resize
          sw-resize
          s-resize
          w-resize
          Crosshair
          Pointer
          Move
          text
          wait
          help

          not-allowed

          13. transform、transition 動畫效果

          transform 轉換,變形

          • origin 定義旋轉基點(left top center right bottom 坐標值) transform-origin: 50px 50px; transform-origin: left;。
          • rotate 旋轉 transform:rotate(50deg) 旋轉角度可以為負數,需要先定義origin。
          • skew 扭曲 transform:skew(50deg,50deg) 分別為相對x軸傾斜,相對y軸傾斜。
          • scale 縮放 transform:scale(2,3) 橫向放大2倍,縱向放大3倍;transform:scale(2) 橫豎都放大2倍。
          • translate 移動 transform:translate(50px, 50px) 分別為相對x軸移動,相對y軸移動。
          <!DOCTYPE html>
          <html>
          <head>
              <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
              <title>nick</title>
              <meta charset="utf-8" />
              <style type="text/css">
                  div {
                      border: 1px solid black;
                      height: 30px;
                      width: 30px;
                      background-color: yellow;
           
                      /*transform-origin: 50px 50px;*/
                      transform-origin: left;
                      transform: rotate(50deg);
                      /*transform: skew(50deg,50deg);*/
                      /*transform: translate(50px,50px);*/
                      /*transform: scale(2);*/
                  }
              </style>
          </head>
          <body>
              <div></div>
          </body>
          </html>


          Transition 平滑過渡

          • transition-property: 變換的屬性(none(沒有屬性改變)、all(所有屬性改變)、具體屬性)
          • transition-duration: 變換持續時間
          • transition-timing-function: 變換的速率(ease:(逐漸變慢)、linear:(勻速)、ease-in:(加速)、ease-out:(減速)、ease-in-out:(加速然后減速)、cubic-bezier:(自定義時間曲線))
          • transition-delay: 變換延遲時間
          • transition: 縮寫
          #property 指定屬性對應類型
          
          1、color: 通過紅、綠、藍和透明度組件變換(每個數值單獨處理),如:background-color,border-color,color,outline-color等CSS屬性;
          
          2、length:真實的數字,如:word-spacing,width,vertical- align,top,right,bottom,left,padding,outline-width,margin,min-width,min- height,max-width,max-height,line-height,height,border-width,border- spacing,background-position等屬性;
          
          3、percentage:真實的數字,如:word-spacing,width,vertical- align,top,right,bottom,left,min-width,min- height,max-width,max-height,line-height,height,background-position等屬性;
          
          4、integer 離散步驟(整個數字),在真實的數字空間,以及使用floor()轉換為整數時發生,如:outline-offset,z-index等屬性;
          
          5、number真實的(浮點型)數值,如:zoom,opacity,font-weight等屬性;
          
          6、transform list。
          
          7、rectangle:通過x、 y、 width和height(轉為數值)變換,如:crop;
          
          8、visibility:離散步驟,在0到1數字范圍之內,0表示“隱藏”,1表示完全“顯示”,如:visibility;
          
          9、shadow:作用于color、x、y、和blur(模糊)屬性,如:text-shadow;
          
          10、gradient:通過每次停止時的位置和顏色進行變化。它們必須有相同的類型(放射狀的或是線性的)和相同的停止數值以便執行動畫,如:background-image;
          
          11、paint server (SVG):只支持下面的情況:從gradient到gradient以及color到color,然后工作與上面類似;
          
          12、space-separated list of above:如果列表有相同的項目數值,則列表每一項按照上面的規則進行變化,否則無變化;
          
          13、a shorthand property:如果縮寫的所有部分都可以實現動畫,則會像所有單個屬性變化一樣變化。
          #支持執行transition效果的屬性
          
          Property Name    Type
          background-color    as color
          background-position    as repeatable list of simple list of length, percentage, or calc
          border-bottom-color    as color
          border-bottom-width    as length
          border-left-color    as color
          border-left-width    as length
          border-right-color    as color
          border-right-width    as length
          border-spacing    as simple list of length
          border-top-color    as color
          border-top-width    as length
          bottom    as length, percentage, or calc
          clip    as rectangle
          color    as color
          font-size    as length
          font-weight    as font weight
          height    as length, percentage, or calc
          left    as length, percentage, or calc
          letter-spacing    as length
          line-height    as either number or length
          margin-bottom    as length
          margin-left    as length
          margin-right    as length
          margin-top    as length
          max-height    as length, percentage, or calc
          max-width    as length, percentage, or calc
          min-height    as length, percentage, or calc
          min-width    as length, percentage, or calc
          opacity    as number
          outline-color    as color
          outline-width    as length
          padding-bottom    as length
          padding-left    as length
          padding-right    as length
          padding-top    as length
          right    as length, percentage, or calc
          text-indent    as length, percentage, or calc
          text-shadow    as shadow list
          top    as length, percentage, or calc
          vertical-align    as length
          visibility    as visibility
          width    as length, percentage, or calc
          word-spacing    as length
          z-index    as integer


          鼠標放在以下圖片上,There will be a miracle:

          <!DOCTYPE html>
          <html>
          <head>
              <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
              <title>nick</title>
              <meta charset="utf-8" />
              <style type="text/css">
                  .img-see-2016-7-2 {
                      background-image: url("http://images.cnblogs.com/cnblogs_com/suoning/845162/o_sea.jpg");
                      background-size: 660px;
                      background-repeat: no-repeat;
                      height: 300px;
                      width: 600px;
          
                      transition-duration: 30s;
                      transition-timing-function: ease;
                      transition-property: background-size;
                  }
                  .img-see-2016-7-2:hover {
                      background-size: 2000px;
                  }
              </style>
          </head>
          <body>
              <div class="img-see-2016-7-2"></div>
          </body>
          </html>

          作者:suoning

          原文鏈接:https://www.cnblogs.com/suoning/p/5625582.html


          lt;h2 id="title1">什么是HTML</h2>

          • HTML其實是HyperText Markup Language的縮寫, 超文本標記語言

          <h2 id="title2">HTML的作用</h2>

          • 1.首先利用記事本保存了一個標題和兩段描述, 然后修改純文本文件的擴展名為.html, 然后再利用瀏覽器打開

          鄭伊健
          鄭伊健,1967年10月4日出生于中國香港,籍貫廣東恩平,香港影視演員、流行男歌手。1988年參加新秀歌唱大賽加入無線電視,因拍攝“陽光檸檬茶”廣告而入行,拜羅文為師。[1] 1991年加盟BMG唱片公司以歌手身份出道。1995年開始,憑借在《古惑仔》系列電影中飾演陳浩南一角走紅。1996年憑借《古惑仔》主題曲《友情歲月》獲得十大中文金曲獎。1996年至1997年連續兩次獲得”臺灣十大偶像”獎。
          • 2.打開之后發現顯示的格式不對, 不對的原因是因為在純文本文件中所有文字都是同級別的, 瀏覽器不知道哪些文字代表什么意思. 也就是瀏覽器不知道哪些文字是標題, 哪些文字是段落...., 所以導致了顯示的格式不正確

          • 正是因為如此, 所以HTML應用而生. HTML就只有一個作用, 它是專門用來描述文本的語義的. 也就是說我們可以利用HTML來告訴瀏覽器哪些是標題, 哪些是段落.

          • 這些用于描述其它文本語義的文本, 我們稱之為標簽. 并且這些用于描述文本語義的標簽將來在瀏覽器中是不會被顯示出來

          • 所以正是因為HTML的這些標簽是專門用來描述其它文本語義的, 并且在瀏覽器中不會被顯示出來, 所以我們稱這些文本為"超文本", 而這些文本又叫做標簽, 所以HTML被稱之為"超文本標記語言"

          <h1>鄭伊健</h1><p>鄭伊健,1967年10月4日出生于中國香港,籍貫廣東恩平,香港影視演員、流行男歌手。1988年參加新秀歌唱大賽加入無線電視,因拍攝“陽光檸檬茶”廣告而入行,拜羅文為師。[1] </p><p>1991年加盟BMG唱片公司以歌手身份出道。1995年開始,憑借在《古惑仔》系列電影中飾演陳浩南一角走紅。1996年憑借《古惑仔》主題曲《友情歲月》獲得十大中文金曲獎。1996年至1997年連續兩次獲得”臺灣十大偶像”獎。</p>

          • 注意事項:

          • 雖然我們利用H1標簽描述一段文本之后, 這段文本在瀏覽器中顯示出來會被放大和加粗, 看上去我們是利用HTML的標簽修改了被描述的那段文本的樣式. 但是一定要記住, HTML只有一個作用, 它是專門用來給文本添加語義的, 而不是用來修改文本的樣式的

          • H1標簽它的作用是什么?

          • 錯誤: H1標簽可以用來修改文字的大小, 并且還可以將文字加粗

          • 正確: H1標簽的作用是用來告訴瀏覽器, 哪些文字是標題. 也就是H1標簽是專門用于給指定的文字添加標題語義


          <h2 id="title3">HTML發展史</h2>

          <h3 id="title4">IETF簡介</h3>

          • IETF是英文Internet Engineering Task Force的縮寫, 翻譯過來就是"互聯網工程任務組"

          • IETF負責定義并管理因特網技術的所有方面。包括用于數據傳輸的IP協議、讓域名與IP地址匹配的域名系統(DNS)、用于發送郵件的簡單郵件傳輸協議(SMTP)等

          <h3 id="title5">W3C簡介</h3>

          • W3C是英文World Wide Web Consortium的縮寫, 翻譯過來就是W3C理事會或萬維網聯盟, W3C是全球互聯網最具權威的技術標準化組織.

          • W3C于1994年10月在麻省理工學院計算機科學實驗室成立。創建者是萬維網的發明者Tim Berners-Lee

          • W3C負責web方面標準的制定,像HTML、XHTML、CSS、XML的標準就是由W3C來定制的。

          Tim Berners-Lee(蒂姆·伯納斯-李),萬維網之父、html設計者、w3c創始人

          百度百科


          <h2 id="title7">網頁的固定格式</h2>

          • 1.編寫網頁和寫信一樣都有一套規范和要求, 這套規范和要求中規定了寫信的固定格式

          • 2.寫信基本結構

          敬愛的江哥:
           您好!
           正文正文正文正文正文正文正文正文正文正文正文正文
          正文正文正文正文正文正文正文正文正文正文正文正文
           此致
          敬禮!
           你的朋友 伊健
           2066年6月6日
          • 3.編寫網頁的步驟:

            3.1.新建一個文本文檔

            3.2.利用記事本打開

            3.3.編寫THML代碼

            3.4.保存并且修改純文本文檔的擴展名為.html

            3.5.利用瀏覽器打開編寫好的文件

          • 4.網頁基本結構:

          <html>
           <head>
           <title></title>
           </head>
           <body>
           </body></html>
          • 5.通過觀察我們發現, HTML基本結構中所有的標簽都是成對出現的, 這些成對出現的標簽中有一個帶/有一個不帶/, 那么這些不帶/的標簽我們稱之為開始標簽, 這些帶/的我們稱之為結束標簽

          <h3 id="title8">html標簽</h3>

          • 作用:

          • 用于告訴瀏覽器這是一個網頁, 也就是說告訴瀏覽器我是一個HTML文檔

          • 注意點:

          • 其它所有的標簽都必須寫在html標簽里面, 也就是寫在html開始標簽和結束標簽中間

          <h3 id="title9">head標簽</h3>

          • 作用:

          • 指定網站的標題 / 指定網站的小圖片

          • 添加網站的SEO相關的信息(指定網站的關鍵字/指定網站的描述信息)

          • 外掛一些外部的css/js文件

          • 添加一些瀏覽器適配相關的內容

          • 用于給網站添加一些配置信息

          • 例如:

          • 注意點:

          • 一般情況下, 寫在head標簽內部的內容都不會顯示給用戶查看, 也就是說一般情況下寫在head標簽內部的內容我們都看不到

          <h3 id="title12">title標簽</h3>

          • 作用:

          • 專門用于指定網站的標題, 并且這個指定的標題將來還會作為用戶保存網站的默認標題

          • 注意點:

          • title標簽必須寫在head標簽里面

          <h3 id="title10">body標簽</h3>

          • 作用:

          • 專門用于定義HTML文檔中需要顯示給用戶查看的內容(文字/圖片/音頻/視頻)

          • 注意點:

          • 雖然說有時候你可能將內容寫到了別的地方在網頁中也能看到, 但是千萬不要這么干, 一定要將需要顯示的內容寫在body中

          • 一對html標簽中(一個html開始標簽和一個html結束標簽)只能有一對body標簽

          • Q群:162542073


          <h2 id="title11">head內部標簽</h2>

          <h3 id="title13">meta標簽</h3>

          • 1.為什么會有亂碼現象?

          • 因為我們在編寫網頁的時候沒有指定字符集

          • 2.如何解決亂碼現象?

          • 在head標簽中添加<meta charset="GBK" />, 指定字符集

          • 3.什么是字符集

          • 字符集就是字符的集合, 也就是很多字符堆在一起. 其實字符集很像我們古代的"活字印刷術", 在活字印刷術中就是將很多刻有漢字的小章放到一個盒子中, 然后需要印刷文字的時候再去盒子中取這個小章出來用, 正是因為如此, 所以導致了亂碼問題

          • 假設北方人和南方人都擁有裝滿小章的盒子, 但是南方人和北方人在盒子中存儲小章的順序不太一樣, 那么這個時候如果北方人和南方人都需要去取"李"字, 在南方人記憶中李字在第6個盒子的第6行的第6列中(666), 在北方人的記憶中李字在第8個盒子的第8行的第8列中(888). 那么此時如果讓一個南方人去北方人的盒子中取"李"字的小章, 必然找不到,, 所以就導致了亂碼問題

          • 這個地方北方人的存儲小章的盒子和南方人存儲小章的盒子就對應網頁中指定的字符集, 在網頁中我們常見的字符集有兩個GBK/UTF-8, GBK就對應北方人存儲的盒子, UTF-8就對應南方人存儲的盒子

          • 所以在網頁中指定字符集的意義就在于告訴瀏覽器我用的是哪個盒子, 你應該如何去查找才能找到對應的正確的內容

          • 4.GBK(GB2312)和UTF-8區別

          • 提交比較大

          • 體積比較小

          • GBK(GB2312)里面存儲的字符比較少, 僅僅存儲了漢字和一些常用外文

          • UTF-8里面存儲的世界上所有的文字

          • 5.那么在企業開發中我們應該使用GBK(GB2312)還是UTF-8呢?

          • 如果你的網站僅僅包含中文, 那么推薦使用GB2312, 因為它的體積更小, 訪問速度更快

          • 如果你的網站除了中文以外, 還包含了一些其它國家的語言 , 那么推薦使用UTF-8

          • 懶人推薦: 不管三七二十一, 一律寫UTF-8即可

          • 6.注意點:

          • 在HTML文件中指定的字符集必須和保存這個文件的字符集一致, 否則還是會出現亂碼

          • 所以僅僅指定字符集不一定能解決亂碼問題, 還需要保存文件的時候, 文件的保存格式必須和指定的字符集一致才能保證沒有亂碼問題


          <h2 id="title14">HTML標簽</h2>

          <h3 id="title15">HTML標簽分類</h3>

          • 單標簽

          • 只有開始標簽沒有結束標簽, 也就是由一個<>組成的

          <meta charset="UTF-8" />
          • 雙標簽

          • 有開始標簽和結束標簽, 也就是由一個<>和一個</>組成的

          <html></html>

          <h3 id="title16">HTML標簽關系分類</h3>

          • 并列關系(兄弟/平級)

          <head></head><body></body>
          • 嵌套關系(父子/上下級)

          <head> <meta charset="UTF-8" />
           <title>百度一下,你就知道123</title></head>

          <h2 id="title17">DTD文檔聲明</h2>

          • 什么是DTD文檔聲明?

          • 由于HTML有很多個版本的規范, 每個版本的規范之間又有一定的差異. 所以為了讓瀏覽器能夠正確的編譯/解析/渲染我們的網頁, 我們需要在HTML文件的第一行告訴瀏覽器, 我們當前這個網頁是用哪一個版本的HTML規范來編寫的. 瀏覽器只要知道了我們是用哪一個版本的規范來編寫之后, 它就能夠正確的編譯/解析/渲染我們的網頁

          • DTD文檔聲明格式:

          <!DOCTYPE html>
          • 注意事項:

          • 不寫也能運行

          • H5網頁里面用H4也能運行

          • <!DOCTYPE>聲明必須是 HTML 文檔的第一行,位于 <html> 標簽之前

          • <!DOCTYPE> 聲明不是 HTML 標簽

          • <!DOCTYPE> 聲明沒有結束標簽

          • <!DOCTYPE> 聲明對大小寫不敏感

          • 這個聲明瀏覽器會看, 但是并不是完全依賴于這個聲明, 瀏覽器有一套自己的默認的處理機制


          • HTML5之前2大種規范, 每種規范中又有3小種規范

          大規范小規范
          HTMLStrict (嚴格的)
          HTMLTransitional(過度的,普通的,寬松的)
          HTMLFrameset(帶有框架的頁面)
          XHTMLStrict (嚴格的)
          XHTMLTransitional(過度的,普通的,寬松的)
          XHTMLFrameset(帶有框架的頁面)
          • HTML的DTD文檔聲明和XHTML的DTD文檔聲明有何區別?

          • XHTML本身規定比如標簽必須小寫、必須嚴格閉合、必須使用引號引起屬性等等, 而HTML會更加松散沒有這么嚴格

          • Strict表示嚴格的, 這種模式里面的要求更為嚴格.這種嚴格主要體現在有一些標簽不能使用

          • 例如font標簽/u標簽等

          • font標簽可以修改一個文本的字號、顏色、字體,但這和HTML的本質有沖突,因為HTML只能負責語義,不能負責樣式,而font標簽是用于修改樣式的,所以在Strict中是不能使用font標簽

          • u標簽可以給一個文本加上下劃線,但這和HTML的本質有沖突,因為HTML只能負責語義,不能負責樣式,而u標簽是用于添加下劃線是樣式.所以在Strict中是不能使用u標簽

          • Transitional表示普通的, 這種模式是沒有一些別的要求

          • 例如可以使用font標簽、u標簽等

          • 但是在企業開發中不會使用這些標簽,因為這違背了HTML的本質, 而是將這些標簽作為css的鉤子使用

          • Frameset表示框架, 在框架的頁面使用

          • 后面學到框架/NodeJS 再做詳細了解

          • 常見的DOCTYPE有如下幾種

          HTML4.01:<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
          "http://www.w3.org/TR/html4/loose.dtd">XHTML 1.0<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
          "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">HTML5:
          <!DOCTYPE html>
          • 有這么多規范我們學習過程中到底使用哪一種比較合適呢?

          • www.baidu.com (B)

          • www.taobao.com (A)

          • www.qq.com (T)

          • www.sohu.com(大奇葩)

          • 無論是HTML還是XHTML,過去企業級開發中用的比較多的大部分都是Transitional類型的文檔聲明

          • 但是HTML5的時代已經到來,以上6中規范僅僅作為了解, 以后都用HTML5類型的文檔聲明, HTML5向下兼容(求此刻WC3心里陰影面積)

          • 目前國內一線網站都更新到了HTML5的文檔聲明, 所以后續授課也是全程使用HTML5的文檔聲明

          <h2 id="title18">HTML和XHTML、HTML5區別</h2>

          • 在HTML的早期發展中,大部分標準都是所謂的retro-spec,即先有實現后有標準。在這種情況下,HTML標準不是很規范瀏覽器也對HTML頁面中的錯誤相當寬容。這反過來又導致了HTML開發者寫出了大量含有錯誤的HTML頁面

          • html語言本身有一些缺陷(例如: 內容和形式不能分離;標簽單一;數據不能復用等等),隨著xml的興起人們希望xml來彌補html的不足,但是目前有成千上萬的網頁都是用html編寫的,所以完全使用xml來替代html還為時過早,于是W3C在2000年推出了xhtml1.0, 建立xhtml的目的就是實現從html向xml的過度

          • 為了規范HTML,W3C結合XML制定了XHTML 1.0標準,這個標準沒有增加任何新的標簽,只是按照XML的要求來規范HTML,并定義了一個新的MIME type application/xhtml+xml。W3C的初衷是要求瀏覽器對這個MIME type實行強錯誤檢查,如果頁面有HTML錯誤,就要顯示錯誤信息。但是由于已有的web頁面中已經有了大量的錯誤,很多開發者拒絕使用新的MIME type。W3C不得已,在XHTML 1.0的標準之后增加了一個附錄C允許開發者使用XHTML語法來寫頁面,同時使用舊的MIME type,application/html,來分發頁面

          • W3C隨后在XHTML 1.1中取消了附錄C,即使用XHTML 1.1標準的頁面必須用新的MIME type來分發。于是這個標準并沒有很多人采用

          • 有了XHTML的教訓,W3C在制定下一代HTML標準時(HTML5),就將向后兼容作為了一個很重要的原則。HTML5確實引入了許多新的特性,但是它最重要的一個特性是,不會break已有的網頁。你可以將任何已有的網頁的第一行改成<!DOCTYPE html>,它就成也一個HTML5頁面,并且可以照樣在瀏覽器里正常的展示。

          • 簡而言之

          • HTML語法非常寬松容錯性強;

          • XHTML更為嚴格,它要求標簽必須小寫、必須嚴格閉合、標簽中的屬性必須使用引號引起等等;

          • HTML5是HTML的下一個版本所以除了非常寬松容錯性強以外,還增加許多新的特性

          <h2 id="title19">.htm 和 .html擴展名區別</h2>

          • DOS操作系統(win95或win98)下只能支持長度為3的后綴名,所以是htm

          • 但在windows后綴長度可以大于3位,所以windows下無所謂htm與html,html是為長文件的格式命名的

          • 所以htm是為了兼容過去的DOS命名格式存在的

          更多內容微信訂閱號:網頁設計輕松學


          主站蜘蛛池模板: 国产成人一区二区动漫精品| 成人精品一区二区三区中文字幕| 精品一区二区三区在线成人| 国产亚洲一区二区三区在线观看| 国产伦精品一区二区免费| 精品国产一区二区三区久久久狼| 日本大香伊一区二区三区| 精品一区二区三区高清免费观看| 激情综合一区二区三区| 亚洲av综合av一区| 亚洲精品色播一区二区| 国产一区二区三区在线| 国产一区二区三区不卡AV| 99精品一区二区三区| 国产微拍精品一区二区| 国产在线一区二区三区| 海角国精产品一区一区三区糖心 | 日美欧韩一区二去三区| 一区二区高清视频在线观看| 国产在线精品一区二区在线观看| 伊人色综合视频一区二区三区| 波多野结衣一区二区三区高清av | 日韩免费一区二区三区在线| 国产一区精品视频| 性色A码一区二区三区天美传媒 | 区三区激情福利综合中文字幕在线一区亚洲视频1 | 波多野结衣在线观看一区二区三区| 国产SUV精品一区二区88L| 久久亚洲综合色一区二区三区| 欧美成人aaa片一区国产精品| 国产成人高清视频一区二区 | 日韩精品一区二区午夜成人版 | 国产裸体歌舞一区二区| 日本一区二区三区精品视频| 精品日产一区二区三区手机| 精品国产区一区二区三区在线观看| 亚洲线精品一区二区三区影音先锋 | 国产精品一区不卡| 亚拍精品一区二区三区| 中文字幕精品亚洲无线码一区应用| 国产成人精品一区二三区熟女 |