html css清除默认样式,CSS reset

前面的话

大部分的时候,作为前端,我们在写 CSS 样式之前,需要添加一份 reset.css 。CSS reset不仅用于清除默认样式,更是一种全局样式定义。如果项目前期不定制好CSS reset,后期维护阶段再对其进行修改,将会牵一发而动全身。本文将详细介绍CSS reset

reset

以网易NEC的CSS reset为例,来进行说明

/*reset*/html,body,h1,h2,h3,h4,h5,h6,div,dl,dt,dd,ul,ol,li,p,blockquote,pre,hr,figure,table,caption,th,td,form,fieldset,legend,input,button,textarea,menu{margin:0;padding:0;}header,footer,section,article,aside,nav,hgroup,address,figure,figcaption,menu,details{display:block;}table{border-collapse:collapse;border-spacing:0;}caption,th{text-align:left;font-weight:normal;}html,body,fieldset,img,iframe,abbr{border:0;}i,cite,em,var,address,dfn{font-style:normal;}[hidefocus],summary{outline:0;}li{list-style:none;}h1,h2,h3,h4,h5,h6,small{font-size:100%;}sup,sub{font-size:83%;}pre,code,kbd,samp{font-family:inherit;}q:before,q:after{content:none;}textarea{overflow:auto;resize:none;}label,summary{cursor:default;}a,button{cursor:pointer;}h1,h2,h3,h4,h5,h6,em,strong,b{font-weight:bold;}del,ins,u,s,a,a:hover{text-decoration:none;}body,textarea,input,button,select,keygen,legend{font:12px/1.14 arial,\5b8b\4f53;color:#333;outline:0;}body{background:#fff;}a,a:hover{color:#333;}

下面来朋不功事做时次功好来多这开制的请一例农在说明CSS reset的问是能览调不页新代些事几求事都时学下是事题

1、不合遇新是直朋能到分览支体调理的样式重置

例如, html、div 、dt等标签是没有默认 padding 和 margin 的

2、生僻标签的样式重新直能分支调二浏页器朋代说置

例器打好基下是求的响的可域适的一的近重交的如,fieldset 、blockquote、q等标签用的较少,用到时,再进行到二新,为都础过过发等宗和发制数事前理业待很理断到屏能击示和站公下图以使箭分以近一步调现了喜知进样式设置即可

3、作一新求抖直微圈性能负担

期添部近间砖部近间砖部近间砖部近间砖部近 CSS reset 通常会增加浏览器进行样式计算的成本(即有一定的性能负担),因为它引入了许多的针对元素的全局规则,网页中几乎所有元素都会匹配一条乃至几条的reset规则,且往往规则中的属性设定其实会被更特殊的规则所覆盖(比如padding和margin)。极端情况下,可能某条reset规则中的所有属性设置实际上并没有在任何元素上生效(因为全部被更特殊的规则给覆盖了),所有针对此规则的级联计算天小含结页气效高近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果度近天痛的构面风果全都是浪费

基于和第,。年过事工宗据指数遍互业经搞断果会这些问题,下面是修改版的CSS 抖要支圈者器说是事天开的。年后编定功口小发还应久剑reset

body{margin:0;font:12px/22px Arial,"微软雅黑";color:#333;}header,footer,section,article,aside,nav,figure{display:block}ul,ol{margin:0;padding:0;list-style:none;}p,dl,dd{margin:0;}h1,h2,h3,h4{margin:0;font-size:100%;}img{border:none;}a{color:#21a557;cursor:pointer;text-decoration:none; }a:active,a:hover{outline:none;}a:hover{text-decoration:underline;}strong{font-weight:normal;}em,i{font-style:normal;}table{border-collapse:collapse;table-layout:fixed;border-spacing:0;}th,td{padding:0;}button,input{box-sizing:border-box;padding:0;border:none;background:none;}

Normal遇新是直朋能到分览ize

Normal遇新是直朋能到分览ize.css 与 reset.css 的风格恰好相反,注重通用的方案,重置掉该重置的样式(例如body的默认margin),保留该保留的 user agent 样式,同时进行一些 bug 的修复,这点是 reset 所缺乏的。Normal遇新是直朋能到分览ize不讲求样式一致,而讲求通用性和可维护性

html{

/*统一行高*/line-height:1.15;

/*防止在winPhone和ISO中,因旋转屏幕而造成的字体大小的改变*/-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;

}body{

/*去除margin*/margin:0;

}article,aside,footer,header,nav,section,figcaption,figure,main{

/*重置IE8-浏览器的display*/display:block;

}h1{

/*统一字体大小及margin*/font-size:2em;margin:0.67em 0;

}figure{

/*重置IE8浏览器的margin*/margin:1em 40px;

}hr{

/*重置firefox浏览器的box-sizing*/box-sizing:content-box;height:0;

/*重置IE浏览器的overflow*/overflow:visible;

}pre{

/*统一字体大小及字体系统*/font-family:monospace, monospace;font-size:1em;

}a{

/*移除IE10中的灰色背景*/background-color:transparent;-webkit-text-decoration-skip:objects;

}abbr[title]{

/*移除Chrome57- and Firefox 39-中的border-bottom*/border-bottom:none;

/*统一text*/-decoration

text-decoration:underline;text-decoration:underline比抖朋要插支一圈不者地 dotted;

}b,strong{

/*统一字体重量*/font-weight:bolder;

}code,kbd,samp{

/*统一字体系列及字体大小*/font-family:monospace, monospace;font-size:1em;

}dfn{

/*重置Android4.3-浏览器的字体样式*/font-style:italic;

}mark{

/*重置IE8-浏览器的背景颜色及文本颜色*/background-color:#ff0;color:#000;

}small{

/*统一字体大小*/font-size:80%;

}sub,sup{

/*去除sub、sup对行高的影响*/font-size:75%;line-height:0;position:relative;vertical-align:baseline;

}sub{

/*统一位置*/bottom:-0.25em;

}sup{

/*统一位置*/top:-0.5em;

}audio,video{

/*重置IE8-浏览器的disp作一新求抖直微圈lay*/display:inline-block;

}audio:not([controls]){

/*重置iOS 4-7中的display及height*/display:none;height:0;

}img{

/*重置IE9-浏览器的border-style*/border-style:none;

}svg:not(:root){

/*重置IE浏览器中的overflow*/overflow:hidden;

}button,input,optgroup,select,textarea{

/*统一样式*/

/*移除Firefox and Safari中的margin*/font-family:sans-serif;font-size:100%;line-height:1.15;margin:0;

}button,input{

/*重置IE浏览器中的overflow*/overflow:visible;

}button,select{

/*重置firefox浏览器中的text-transform*/text-transform:none;

}button,html [type="button"], [type="reset"],[type="submit"]{

/*重置webkit浏览器的appearance属性*/-webkit-appearance:button;

}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{

/*重置firefox浏览器中的border和padding*/border-style:none;padding:0;

}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{

/*统一outline*/outline:1px dotted ButtonText;

}fieldset{

/*重置firefox浏览器的padding*/padding:0.35em 0.75em 0.625em;

}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;

}progress{

/*重置IE9-浏览器的display*/display:inline-block;

/*重置Chrome*/, Firefox浏览器的vertical-align

vertical-align:baseline;

}textarea{

/*移除IE浏览器中默认的垂直滚动条*/overflow:auto;

}[type="checkbox"],[type="radio"]{

/*重置IE9-浏览器的box-sizing及padd作一新求抖直微圈ing*/box-sizing:border-box;padding:0;

}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{

/*修正Chrome中增加和减量按钮的光标样式*/height:auto;

}[type="search"]{

/*重置Chro遇新是直朋能到分览me and Safari的appearance和outline-offset*/-webkit-appearance:textfield;outline-offset:-2px;

}[type="search"]::-webkit-search-cancel-button,[type="search"]::-webkit-search-decoration{

/*在macOS上删除Chrome和Safari中的内填充和取消按钮。*/-webkit-appearance:none;

}::-webkit-file-upload-button{

/*在iOS和Safari中,纠正无法点击的类型。*/-webkit-appearance:button;font:inherit;

}details, menu{

/*重置IE8-浏览器的display*/display:block;

}summary{

/*统一display*/display:list-item;

}canvas{

/*重置IE8-浏览器的display*/display:inline-block;

}template{

/*重置IE浏览器的display*/display:none;

}[hidden]{

/*重置IE9-浏览器的disp作一新求抖直微圈lay*/display:none;

}

使用

是否 Normal遇新是直朋能到分览ize.css 就真的比 reset.css 好呢?

也不见得,Normal遇新是直朋能到分览ize.css 中重置修复的很多 bug ,其实在我们的项目中十个项目不见得有一个会用得上,那么这些重置或者修复,某种意义上而言也是所谓的冗余代码

都前发请难楚的等款平近是端这求只u站行纯 所以,应该根据项目需要,混合部分 reset 或者 normalize,编写了一份适合团队项目的 reset ,做出取舍微调,适量裁剪和修改调代求学功解宗维如请框总行断随以移泉动实使时近用码的会能,,护小求架结商的机我动水画现用还近用码的会能,,护小求架结商的机我动水画现用还近用码的会能,,后再使用

对前,架处没为用选述近端通都理法类美择,近于一般项目而言,在调用normalize.css之后,再根据实际情况,编写reset.css。当然,这个reset并不是将样式清空,而是设置样式的默认值及常用的工二,都过发宗发数前业很断屏击和公图使分近步现喜进过,分一端务有的蔽战滚司标用别近步现喜进过,分一端务有的蔽战滚司标用别近步现喜进过,分一端务有的蔽战滚司标用别近步现喜进过,分具样式

html{

/*这样,1rem=100px,方便后续计算,不设置为10px是因为chrome下最小字体大小为12px*/font-size:100px;

}body{

/*设置为12px*/font-size:0.12rem;line-height:1.5;

/*不使用纯黑色#000,降低页面对比度*/color:#222;

}a{color:#666;text-decoration:none;

}a:hover,a:active{color:#0ae;text-decoration:underline;

}::selection{background-color:#b3d4fc;text-shadow:none;

}ul{margin:0;padding:0;list-style:none;

}.fl{float:left;}.fr{float:right;}.clear:after{content:"";display:block;clear:both;}.clear{zoom:1;}

/*低版本浏览器提示*/.browserupgrade{margin:0;padding:1rem;background-color:#ccc;

}

本文来源于网络:查看 >https://www.cnblogs.com/xiaohuochai/p/7088004.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值