CSS3和HTML5新增特性及使用(保留方便查看)

CSS3javascript

1.邊框圖片 border-image: url(test.png) 10/10px;  outline:10px solid #ff0;outline-offset:15px;邊框的邊框,兩邊框之間距離css

2.三角形   span{display:inline-block;border:50px solid transparent;border-top-color:red;border-left-color:red;}     html

3.背景大小  background-size:50%/100px 200px/cover/contain;//原圖50%/寬爲100px 200px/覆蓋/容納html5

4.陰影    box-shadow:red 0px 0px 10px 0px inset/outside;陰影顏色 X偏移 Y偏移 陰影模糊半徑 擴展半徑java

          內部/外部顯示  陰影累加box-shadow:red 0px 0px 10px 0px inset,green 0px 0px 10px 0px outside;git

           文本陰影: text-shadow:red 0px 0px 10px; 陰影顏色,X偏移,Y偏移,模糊半徑web

5.圓角   邊框圓角border-radius:5px/10%;   border-radius:50%:圓小程序

          border-radius:150px 150px 0px 0px;/ border-radius:20px 100px 0px;/border-radius:20px 100px;api

          border-top-left-radius:150px;/border-top-left-radius:130px 40px;瀏覽器

6.HSLA   background:hsla(0,100%,100%,0.5); 色調,飽和度,亮度,透明度//(0,0%,100%)白;(0,0%,0%)黑

7.RGB    backgrund:rgb(255,0,0) 三個值的範圍爲0~255    

          (255,0,0)紅;(0,255,0)綠,(0,0,255)藍; (255,255,0)黃;(0,0,0)黑,(255,255,255)白

8.漸變   ①線性漸變:background: linear-gradient(#fff, #333);  //由#fff漸變爲#333

            background: linear-gradient(#000, #f00 50%, #090); //由#00漸變爲#f00,並佔50%,最後爲#090,

            background:linear-gradient(0deg,yellow 50px,blue 51px,blue 100px,#F89 101px,#F89 200px);

            從下到上黃色高度0-50px,藍色高度50-100px,#f89高度101-200px

            background:linear-gradient(0deg,yellow 50px,blue 100px,#F89 200px);從下到上漸變

         重複線性漸變:background:repeating-linear-gradient(45deg,#FFF,#FFF 45px,#ccc 46px);

      ②徑向漸變:background:radial-gradient(100px 100px,yellow,blue); 從內到外由yellow變爲blue,   

            background:radial-gradient(100px 500px at 50px 10px,yellow,blue);

            內部寬100px;高50px的黃色圓在距上面50px左邊10px漸變爲藍色        

             重複徑向漸變:background:repeating-radial-gradient(yellow,yellow 20px,blue 21px,blue 40px);

9.White-space處理文字空白:pre保留html中的格式nowrap強制不折行,直到遇到br標籤+overflow:

  hidde超出部分隱藏+text-overflow:ellipsis;以省略號的形式顯示, (overflow:auto;帶滾動條的隱藏)

 div{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}   div:hover{white-space: normal;}文字顯示一行,劃過所有顯示

10.連接字體 @font-face { font-family : name ; src : url( url ) ; } 

       url('../font/lie_to_me_-_ttf-webfont.otf') format('otf'),  url('../font/lie_to_me_-_ttf-webfont.ttf') format('ttf'),

       url('../font/lie_to_me_-_ttf-webfont.woff2') format('woff2'), url('../font/lie_to_me_-_ttf-webfont.woff') format('woff');

11.文本域的自由縮放resize:both;overflow:auto/horizontal/vertical; 總體/高/寬縮放

12.建立伸縮容器  display:flex;伸縮流方向;默認水平/row;豎直;column; 伸縮性:flex:2;容器按比例分配額外空間。

13.縮放    transform-origin:10% 20px;transform:scale(1.5,0.5);以X軸10%,Y軸的20px爲中心點

           縮放爲原來的寬1.5倍,高0.5倍;//只有一個數值時寬高縮放一致。

14.旋轉    div{transition:2s;}   div:hover{transform:rotateY(180deg);}  滑過div時2秒旋轉180度

15.變形    transform:skew(-30deg,10deg) 內容逆時針傾斜30%;總體順時針旋轉10度;

16.位移    transform:translate(20px,40px);向水平方向位移20px;向豎直方向位移40px;

           例:p:hover{ transform:translate(1000px) rotate(360deg);}

模塊移動(文字、圖片):  兩次移動

font:normal 40px/1.5 'Ultra','Curlz MT','Bauhaus 93','Blackoak Std',Courier,Arial;color:#7e9409; -moz-animation: 3s slidein; -webkit-animation: 3s slidein; -webkit-perspective: 100; -moz-perspective: 300px; }

@-moz-keyframes slidein { from {top:-100px;} 85% {top:80%;} to {top:70%;} }

@-webkit-keyframes slidein { from {top:-100px;} 85% {top:80%;} to {top:70%;}    }

17.過渡    p:hover{ transform: translate(1000px); background:blue;color:#000;height:500px; }

    p{transition:transform 2s ease-in 0.5s,background 1s ease-out,color 5s ease-in-out,height 1s lincar;}       

    p:hover{ transform: translate(1000px); background:blue;color:#000;height:500px; }

    2s內加速位移1000px且延遲0.5s開始;1s內背景減速變藍,

    5s內字體顏色先加速再減速變白,1s內高度恆速變爲500px

18.動畫   p:hover{animation-play-state:paused;}

p{animation:a1 5s ease-in;animation-iteration-count:3;animation-direction:alternate;animation-fill-mode:forwards;}

@keyframes a1{ 0%{ transform:translate(0p,0px);} 30%{transform:translate(500px,0px);}

50%{transform:translate(1000px,300px);} 70%{transform:translate(300px,500px);}

100%{transform:translate(1300px,800px)} }     

19.鼠標指針變化:變成抓手cursor:pointer;   cursor:move;  

HTML5

 1.插入音頻:  支持格式:Oggvorbis、MP3和WAV

  <audio  src=」a.mp3」 >    屬性:controls包含基本的播放控件(開始、結束、音量、位置)   

  preload=」auto/metadate/none」  音頻文件的下載方式:整個文件/音頻時長和開頭/不預先下載

  Loop/autoplay  無限次播放/自動播放  例:<audio src=」a.mp3」 controls preload=」metadate」 autoplay >

  <source src="soundfile.ogg" type="audio/ogg">調整兼容

2.插入視頻: 支持格式:OGG、MP四、WEBM

   <video  src=」b.mp4」 poster=」1.jpg」>當視頻文件失效時,用poster圖片代替原圖片顯示,其它屬性與audio相同

   <video controls>      <source src="butterfly.mp4" type="video/mp4" >

             <source src="butterfly.ogv" type="video/ogg">

            <p>兩種格式都不支持的瀏覽器看到的是這行文字</p>

       <object type="application/x-shockwave-flash" data="flowplayer-3.2.16.swf" width="500" height="375">

    <param name="movie" value="flowplayer-3.2.16.swf">    <param name="flashvars" value='config={"clip":"butterfly.mp4"}' />

<p>若是html5標籤和flash格式都不識別,請點擊下載

                      <a href="butterfly.mp4">butterfly.mp4</a>或者<a href="butterfly.ogv">butterfly.ogv</a>  </p>

</object>

  </video>

  <hr>

  <!--flash爲主html5爲輔,不識別點擊下載a-->

  <object type="application/x-shockwave-flash" data="flowplayer-3.2.16.swf" width="500" height="375">

<param name="movie" value="flowplayer-3.2.16.swf">

<param name="flashvars" value='config={"clip":"butterfly.mp4"}' />

<video controls>

<source src="butterfly.mp4" type="video/mp4">

<source src="butterfly.ogv" type="video/ogg">

<p>若是html5標籤和flash格式都不識別,請點擊下載

                      <a href="butterfly.mp4">butterfly.mp4</a>或者<a href="butterfly.ogv">butterfly.ogv</a>  </p>     

      </video>

  </object>

3.<object>元素定義了在 HTML 文檔中嵌入的對象,例如在網頁中嵌入 Java 小程序, PDF 閱讀器, Flash 播放器) 。

<object width="400" height="50" data="bookmark.swf"></object>

<object width="100%" height="500px" data="snippet.html"></object>

 

4.新增html5佈局標籤

   ·<article> 標籤訂義外部的內容。

外部內容能夠是來自一個外部的新聞提供者的一篇新的文章,或者來自 blog 的文本,或者是來自論壇的文本。亦或是來自其餘外部源內容

·<aside> 頁面或站點主題以外的內容,可用在文章的側欄

·<blockquote> 標籤訂義摘自另外一個源的塊引用。

·<center> 標籤對其包圍的文本進行水平居中處理。

 ·<figure> 獨立於文本流以外的一段內容,如圖片和圖標等

·<figcaption>  figure中的標題

·<header>文檔的頁眉

·<footer>文檔的頁腳

·<nav>導航

·<section>文章的章節

·<detials>包含下拉隱藏效果的內容

·<summary>嵌套在detials中的概要或標題

·<mark>被突出標記的內容

·<meter>計量器    ·<adress>地址標記

·<program>進度指示

4.新增表單標籤

<input  type=」search」>   搜索框

<input  type=」search」>   搜索框

<input  type=」email」>    郵箱輸入

<input  type=」range」>   顯示進度條  

<input  type=」tel」>      電話號碼輸入      

<input  type=」number」>  數字輸入

<input  type=」URL」>   網址輸入

<input  type=」date」>    日期類型(帶時間控件)  

<input  type=」datetime」>  日期類型(不帶時間控件)

<input  type=」week」>    選擇星期(帶時間控件)

<input  type=」month」>   選擇年月(帶時間控件)

<input  type=」datetime-local」>年、月、日、時、分(帶時間控件)    

4.網頁title滾動

<script type="text/javascript">

function scroll() {

var titleInfo = document.title;

var firstInfo = titleInfo.charAt(0);

var lastInfo = titleInfo.substring(1, titleInfo.length);

document.title = lastInfo + firstInfo;

}

setInterval("scroll()", 500);

</script>

5.獲取地理位置

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title>菜鳥學堂</title>

</head>

<body>

<p id="demo">點擊按鈕獲取您當前座標(可能須要比較長的時間獲取):</p>

<button onclick="getLocation()">點我</button>

<div id="mapholder"></div>

<script src="http://maps.google.com/maps/api/js?sensor=false"></script>

<script>

var x=document.getElementById("demo");

function getLocation()

{

if (navigator.geolocation)

{

navigator.geolocation.getCurrentPosition(showPosition,showError);

}

else

{

x.innerHTML="該瀏覽器不支持獲取地理位置。";

}

}

 

function showPosition(position)

{

lat=position.coords.latitude;

lon=position.coords.longitude;

latlon=new google.maps.LatLng(lat, lon)

mapholder=document.getElementById('mapholder')

mapholder.style.height='250px';

mapholder.style.width='500px';

 

var myOptions={

center:latlon,zoom:14,

mapTypeId:google.maps.MapTypeId.ROADMAP,

mapTypeControl:false,

navigationControlOptions:{style:google.maps.NavigationControlStyle.SMALL}

};

var map=new google.maps.Map(document.getElementById("mapholder"),myOptions);

var marker=new google.maps.Marker({position:latlon,map:map,title:"You are here!"});

}

 

function showError(error)

{

switch(error.code)

{

case error.PERMISSION_DENIED:

x.innerHTML="用戶拒絕對獲取地理位置的請求。"

break;

case error.POSITION_UNAVAILABLE:

x.innerHTML="位置信息是不可用的。"

break;

case error.TIMEOUT:

x.innerHTML="請求用戶地理位置超時。"

break;

case error.UNKNOWN_ERROR:

x.innerHTML="未知錯誤。"

break;

}

}

</script>

</body>

</html>

 

 

 

附一:.響應式佈局

      Pc: 1902px   1600px   1366px   1280px

     平板  1024px   992px    768px     ipad豎屏768X1024

     手機  767px    480px    414px     414X395  375X365

外部樣式:

  <link rel="stylesheet" href="css/1.css" media="screen">    //user-scalable=no"頁面不進行縮放

   <link rel="stylesheet" href="css/2.css" media="screen and (max-width:480px)">  

//手機頁面自適應

   <meta name="viewport" content="width:device-width,initial-scale=1.0,maximum-scale=1,user-scalable=no">   

   <!-- 如下方式只是刷新不跳轉到其餘頁面 -->

<meta http-equiv="refresh" content="10">

<!-- 如下方式定時轉到其餘頁面 -->

<meta http-equiv="refresh" content="5;url=hello.html">

javascript的實現

<script language="javascript" type="text/javascript">

// 如下方式直接跳轉window.location.href='hello.html';

// 如下方式定時跳轉setTimeout("javascript:location.href='hello.html'", 5000);

</script>

導入樣式

      <style>   @import url('css/base.css') screen;   @import url('css/1024.css') screen and (max-width:1024px);

        @import url('css/767.css') screen and (max-width:767px);

      </style>

附二:.聖盃佈局

    <header>header頭部</header>

    <nav>nav導航</nav>

    <div>

        <aside>aside側欄</aside>

    <article>article文章</article>

    </div>

    <footer>footer</footer>      

附三:大型門戶站基礎css樣式命名和應用原則

1.CSS命名規範。

  全局樣式 base.css 公共塊的樣式;    首頁樣式 index.css

   內容頁面的樣式 content.css        頻道頁面樣式 channel.css    詳細頁面樣式 detail.css

2.頁面框架結構保留字。

頁面容器:#wrapper

頁面頭部:#header #head

頁面中心內容:#maincontent

頁面底部:#footer #foot

橫向方位容器1:main,side

橫向方位容器2:leftframe,midframe,rightframe

橫向分段容器:section,field,column

盒子內容屬性:contentbg

盒子上方屬性:topbg

盒子下方屬性:bottombg

盒子左邊屬性:leftbg

盒子右邊屬性:rightbg

3.導航保留字。

導航:nav

主導航:mainnav

子導航:subnav

頂導航:topnav

邊導航:sidebar

左導航:leftsidebar

右導航:rightsidebar

菜單:menu

快速菜單:quickmenu

子菜單:submenu

下拉菜單:dropmenu

 

4.功能保留字。

列表:list

標題:title

摘要:intro

內容:text

按扭:btn

搜索:search

登錄:login

註冊:regsiter

提示信息:msg

小技巧:tips

圖標: icon

滾動:scroll

 

 

 

附四

(1).一段時間後頁面自動跳轉:

    在head中<meta http-equiv=」refresh」 content=」5;url=網頁地址(可設置刷新效果)」

(2).網頁關鍵詞與介紹:

<meta name="keyword" content="廚房 廚具 衛具 廚房家電 ">

相關文章
相關標籤/搜索