为什么使用Html5+CSS3

一:大多浏览器支持,低版本也没问题html

    我看点这方面的资料,是为了作手机应用网站(有三个方案,这个是备用方案),能够开发响应式网站,能够脱离开发平台进行跨平台。html5

    在Html5网页中引入Modernizr,就能让IE支持HTML5新元素。web

    HTML5样板文件快速开发(html5boilerplate.com)正则表达式

二:布局、标签省时省力浏览器

  

  1. <header>  
  2.     <!--语义至关于<div class="header">-->  
  3.     <nav>导航</nav>  
  4. </header>  

 

这样开发者就不用标记标签的结束位置了,定位时会很方便,也易于搜索引擎进行判断。app

<header>定义页面或区段的头部;ide

<footer>定义页面或区段的尾部;布局

<nav>定义页面或区段的(主)导航区域;post

<section>页面的逻辑区域或内容组合,好比一个用于“简介”,另外一个用于“新闻列表”。字体

<article>定义正文或一篇完整的内容,能被直接粘贴到别的地方有独立意义,好比“博客正文”。

<aside>定义补充或相关内容,侧边栏,广告栏等。

<a>标签能够包含多个标签

 
  1. <href="index.html"><h2>一</h2><img src="home.jpg"></a>  

<vedio>、<audio>快速添加视频、音频

 
  1. <video src="myVideo.ogg" controls width="640" height="480">这里提示你没有使用支持HTML5的浏览器</video> //controls播放控制栏;支持ogg和mp4格式;响应式视频:普通状况可使用max-width:100% height:auto,若是是外部<iframe>视频,则使用FitVids的jQuery插件  


三:离线Web应用

    经过.manifest文件指定哪些文件能够离线访问的


 

四:更灵活的CSS3

01.能够多栏显示文本

column-width:12em; //试了几个浏览器好像不少无效的~

 

02.众多选择器

body[id="2^"]{}  //id为"2"开头的标签

li:first-child 、 li:last-child  //针对列表的首尾项

 
  1. li:nth-child(2n+1)//第“1”个li元素起,每“2”个颜色为红色          
  2.   
  3.         color: red;  
  4.     }    
  5.  <ul>  
  6.     <li>һһһһһ</li>  
  7.     <li>22222222</li>  
  8.     <li>33333333</li>  
  9. </ul>  

p::first-line{color:red;} //第一行文字为红色

五:更丰富CSS3

传统CSS实现圆角、阴影等效果,通常要借助图片来实现,使用CSS3代替图片,能够有效减小http请求,取得更快的网页加载速度。不一样浏览器对不一样的CSS特性可能要使用不一样的代码,可使用预处理器SASS或LESS才处理。

01.CSS3轻松应用边框圆角

 
  1. <html>  
  2. <head>  
  3.     <style>  
  4.         a  
  5.         {  
  6.             background-color:red;  
  7.             border-top-left-radius:8px;/*圆角位置和大小*/  
  8.             border-top-right-radius:8px;  
  9.             padding:0.8em;  
  10.         }  
  11.     </style>  
  12. </head>  
  13. <body>  
  14.     <br />  
  15.     <href="#">圆角</a>  
  16. </body>  
  17. </html>  

02.可使用@font-face嵌入网页字体,还可使用可缩放的ICON(非图片格式,fico.lensco.be)

 

03.使用透明通道

 
  1.     <style>  
  2.         body{  
  3.     background:url(01.jpg) no-repeat;  
  4.     }  
  5.     #wrapper{  
  6.     background-color:hsla(100,100%,100%,0.7);/*HSL是360度色相环*/  
  7.     width:500px;  
  8.     height:500px;  
  9.     }  
  10.     </style>  
  11. </head>  
  12. <body>  
  13.     <div id="wrapper">  
  14.     透明区域  
  15.     </div>  
  16. </body>  

04文字阴影

[html]  view plain  copy
 
  1. text-shadow:5px 5px 2px #333; //(正负)右、下、阴影程度、颜色  

浮雕效果:

[html]  view plain  copy
 
  1. <head>  
  2.     <style>  
  3.     #wrapper{  
  4.         height:500px;  
  5.         background-color:ActiveBorder;  
  6.         text-shadow:0px 1px 0px hsla(0,0%,100%,0.75);  
  7.         font-size:30px;  
  8.     }  
  9.     </style>  
  10. </head>  
  11. <body>  
  12.     <div id="wrapper">  
  13.     浮雕效果  
  14.     </div>  
  15. </body>  

同理可使用盒阴影box-shadow给照片加阴影
05颜色渐变

[html]  view plain  copy
 
  1. background:linear-gradient(90deg,red 0%,blue 50%,#ffffff 100%);  

能够控制线性渐变方向渐变位置等,还有径向(球状)渐变
06文字2D变形

代码参数比较多,在网站 http://www.useragentman.com/matrix/ 进行制做吧

以外还有图片3D效果,貌似用得还很少。http://webdesignerwall.com/ 这里有不少很酷的关于这方面的内容,我还特别在里面找了一篇文章翻译出来了:http://blog.csdn.net/wowkk/article/details/12572447

最后说下表单的优点,HTML5能够在不借助jQuery的状况下,对用户的输入行为进行判断(某些浏览器对HTML5表单支持也不是很好,能够经过Webshims Lib来解决)。

 
  1. <head>  
  2.     <style>  
  3.         /*伪选择器*/  
  4.         .input:required /*若是没有填入必填项,则边框变红色*/  
  5.         {  
  6.             border:1px solid #f00;  
  7.         }  
  8.         .input:focus:invalid /*若是填入的数据无效时*/  
  9.         {  
  10.         }  
  11.         .input:focus:invalid /*若是填入的数据正确时*/  
  12.         {  
  13.         }  
  14.     </style>  
  15. </head>  
  16. <body>  
  17.     <form method="post">  
  18.         <div>  
  19.             <label for="userName">请输入用户名</label>  
  20.             <input id="userName" type="text" placeholder="例如:Admin" required aria-required="true" autofocus />  
  21.             <!--placeholder表示提示输入  
  22.                 required aria-required="true"表示为必填项;  
  23.                 autofocus表示自动获取到光标焦点  
  24.                 pattern属性能够填正则表达式,能够断定用户的输入行为  
  25.                  -->  
  26.             <input type="search" value="与text差很少,部分浏览器表现比较强悍" />  
  27.             <!--此外还有type=number之类的-->  
  28.             <input type="submit" value="肯定" />  
  29.         </div>  
  30.     </form>  
  31. </body>  


补充:

使用HTML5 Boilerplate来写HTML5网站,它带有组织好的文件夹结构和CSS文件,加入当前编码的最佳实践、浏览器的bug修复以及js库。 

相关文章
相关标签/搜索