CSS Normalize文件配置示例

我做不到很坚强,但起码要让自己不再懦弱!人生最大的错误,是用健康换取身外之物,人生最大的悲哀,是用生命换取个人的烦恼,人生最大的浪费,是用生命解决自己制造的麻烦!

作为前端工程师,很多人都有自己的一套CSS Normalize文件,这样能省掉开发过程中的不少麻烦,提高工作效率。在前人的基础上,我总结了自己的CSS Normalize文件,目前基本上每个项目都有在使用中:

CSS Code复制内容到剪贴板
  1. /*Normalize*/
  2. *{margin:0;padding:0;list-style-type:none;}
  3. *html,*htmlbody/*修正IE6振动bug*/{
  4. background-image:url(about:blank);
  5. background-attachment:fixed;
  6. }
  7. body{
  8. font-family:"MicrosoftYahei","HiraginoSansGB",Arial,Lucida,Verdana,SimSun,Helvetica,sans-serif;
  9. /*font-size:62.5%;px数值除以10,然后换上em作为单位*/
  10. /*min-width:980px;*/
  11. font-size:13px;
  12. }
  13. a,img{border:none;text-decoration:none;}
  14. a{blr:expression(this.onFocus=this.blur());}/*去掉a标签的虚线框,避免出现奇怪的选中区域*/
  15. /*a:active{test:expression(target="_blank");}*/
  16. :focus{outline:0;}
  17. label{cursor:pointer;}
  18. img{vertical-align:middle;}
  19. table{empty-cells:show;border-collapse:collapse;border-spacing:0;}
  20. h1{font-size:1.6em;}h2,h3,h4{font-size:1.4em;}h5,h6{font-size:1.2em;}
  21. input{border:none;}
  22. textarea{overflow:scroll;}
  23. a,input,textarea,.hover-delay{
  24. font-family:"MicrosoftYahei","HiraginoSansGB",Arial,Lucida,Verdana,SimSun,Helvetica,sans-serif;
  25. -webkit-transition:all0.3sease-out;
  26. -moz-transition:all0.3sease-out;
  27. -ms-transition:all0.3sease-out;
  28. -o-transition:all0.3sease-out;
  29. transition:all0.3sease-out;
  30. }
  31. input.none-radius{
  32. border-radius:0;
  33. -moz-border-radius:0;
  34. -webkit-border-radius:0;
  35. }
  36. input::-ms-clear{display:none;}//去掉输入框的叉叉
  37. .clear{clear:both;}
  38. .txt-indent{text-indent:-999px;overflow:hidden;}
  39. input[type=text],input[type=tel],input[type=email]{
  40. -webkit-appearance:none;
  41. box-shadow:none;}
  42. /*Normalizeend*/

对与我的实际使用中,我有一个Template文件夹(最近新增了一个针对Mobile)
里面的文件夹大致分为如下:

1)images: 存放项目中的图片(里面又会根据项目模块进行文件夹划分)
2)css: 存放css文件(里面会有一个base.css文件,预置上文中的css normalize)
3)js:存放js文件,里面还有一个vender的文件夹,存放插件js(例如:jQuery库),外面有main.js(主要js文件),plugins.js(插件引用的js)

根目录下,为index.html文件
主要为如下文件:

CSS Code复制内容到剪贴板
  1. <!doctypehtml>
  2. <!--[ifltIE7]><htmlclass="no-jslt-ie9lt-ie8lt-ie7"><![endif]-->
  3. <!--[ifIE7]><htmlclass="no-jslt-ie9lt-ie8"><![endif]-->
  4. <!--[ifIE8]><htmlclass="no-jslt-ie9"><![endif]-->
  5. <!--[ifgtIE8]><!--><htmlclass="no-js"><!--<![endif]-->
  6. <headlang="zh-CN">
  7. <metacharset="utf-8"/>
  8. <metahttp-equiv="X-UA-Compatible"content="IE=edge"/>
  9. <title>xxx</title>
  10. <metaname="keywords"content="xxx"/>
  11. <metaname="description"content="xxx"/>
  12. <linkrel="shortcuticon"rel="nofollow noopener noreferrer" href="images/favicon.ico"/><!--IEaddress前ico图标-->
  13. <linkrel="stylesheet"rel="nofollow noopener noreferrer" href="css/normalize.css"/><!--resetstyle-->
  14. <linkrel="stylesheet"rel="nofollow noopener noreferrer" href="css/base.css"/><!--basicstyle-->
  15. <scriptsrc="js/vendor/jquery-1.10.2.min.js"></script><!--jQuerylibrary-->
  16. <scriptsrc="js/vendor/jquery-ui-1.11.1.js"></script><!--jQueryUIlibrary-->
  17. <scriptsrc="js/main.js"></script><!--mainjs-->
  18. <scriptsrc="js/plugins.js"></script><!--plugins-->
  19. <!--[if(gteIE6)&(lteIE8)]>
  20. <scripttype="text/javascript"src="js/vendor/selectivizr.js"></script>
  21. <noscript><linkrel="stylesheet"rel="nofollow noopener noreferrer" href="[fallbackcss]"/></noscript>
  22. <![endif]--><!--/*修正CSS3在IE6-8*/-->
  23. <!--[ifltIE9]>
  24. <scriptsrc="js/html5.js"></script>
  25. <![endif]-->
  26. </head>
  27. <body>
  28. <!--wrapper-->
  29. <divclass="wrapper">
  30. <!--header-->
  31. <divclass="header">
  32. <!--logo-->
  33. <divclass="logo"></div>
  34. <!--logoend-->
  35. <!--navigation-->
  36. <divclass="nav">
  37. </div>
  38. <!--navigationend-->
  39. <!--banner-->
  40. <divclass="banner">
  41. </div>
  42. <!--banner-->
  43. </div>
  44. <!--headerend-->
  45. <!--container-->
  46. <divclass="container">
  47. <!--news-->
  48. <divclass="news">
  49. </div>
  50. <!--newsend-->
  51. <!--sidebarbanner-->
  52. <divclass="sidebar">
  53. </div>
  54. <!--sidebarbannerend-->
  55. <!--hottop9-->
  56. <divclass="hot">
  57. </div>
  58. <!--hottop9-->
  59. </div>
  60. <!--containerend-->
  61. <!--footer-->
  62. <divclass="footer">
  63. <!--aboutus-->
  64. <divclass="about-us"></div>
  65. <!--webchat-->
  66. <divclass="webchat"></div>
  67. <!--copyright-->
  68. <divclass="copyright"></div>
  69. </div>
  70. <!--footerend-->
  71. </div>
  72. <!--wrapperend-->
  73. </body>
  74. </html>

Mobile下的head会有如下meta设置:

CSS Code复制内容到剪贴板
  1. <metaname="viewport"id="viewport"content="width=device-width,initial-scale=1,user-scalable=no"/>
  2. <metaname="apple-mobile-web-app-capable"content="yes"/>
  3. <metaname="apple-touch-fullscreen"content="yes"/>
  4. <metaname="apple-mobile-web-app-status-bar-style"content="black"/>

值得一提的是,在github上也有做了一个 normalize.css 文件,我在做HTML5项目也将其应用在normalize中。 链接如下:
https://github.com/necolas/normalize.css

另外,对于很多开发中来说,Template文件同样是节省了不少写重复代码的时间,同时,又规范了自己的书写习惯。
下面这个,我觉得非常详细了,当然有些不必要的东西,可以自己取舍。
https://github.com/h5bp/html5-boilerplate

本文CSS Normalize文件配置示例到此结束。人生如逆旅,我亦是行人。小编再次感谢大家对我们的支持!

您可能有感兴趣的文章
css让页脚保持在底部位置的四种方案

Flex布局史上最简单使用语法教程

新的CSS 伪类函数 :is() 和 :where()示例详解

纯CSS打字动画的如何实现示例

CSS浮动引起的高度塌陷问题