12 个 CSS 高级技巧汇总

来源:互联网 发布:那个软件有柯南漫画 编辑:程序博客网 时间:2024/06/01 08:39
  • 使用 :not() 在菜单上应用/取消应用边框

  • 给body添加行高

  • 所有一切都垂直居中

  • 逗号分隔的列表

  • 使用负的 nth-child 选择项目

  • 对图标使用SVG

  • 优化显示文本

  • 对纯CSS滑块使用 max-height

  • 继承 box-sizing

  • 表格单元格等宽

  • 用Flexbox摆脱外边距的各种hack

  • 使用属性选择器用于空链接


 使用 :not() 在菜单上应用/取消应用边框

  先给每一个菜单项添加边框

/* add border */.nav li {  border-right: 1px solid #666;}

  ……然后再除去最后一个元素……

//* remove border */

.nav li:last-child {  border-right: none;}

  ……可以直接使用 :not() 伪类来应用元素:

.nav li:not(:last-child) {  border-right: 1px solid #666;}

  这样代码就干净,易读,易于理解了。

  当然,如果你的新元素有兄弟元素的话,也可以使用通用的兄弟选择符(~):

..nav li:first-child ~ li {

  border-left: 1px solid #666;}

 给 body添加行高

  你不需要分别添加 line-height 到每个 <p>,<h*>等。只要添加到 body 即可:

body {  line-height: 1;}

  这样文本元素就可以很容易地从 body 继承。

 所有一切都垂直居中

  要将所有元素垂直居中,太简单了:

html, body {  height: 100%;  margin: 0;}body {  -webkit-align-items: center;    -ms-flex-align: center;    align-items: center;  display: -webkit-flex;  display: flex;}

  看,是不是很简单。

  注:在IE11中要小心flexbox。

 逗号分隔的列表

  让HTML列表项看上去像一个真正的,用逗号分隔的列表:

ul > li:not(:last-child)::after {  content: ",";}

  对最后一个列表项使用 :not() 伪类。

 使用负的 nth-child 选择项目

  在CSS中使用负的 nth-child 选择项目1到项目n。

li {  display: none;}/* select items 1 through 3 and display them */li:nth-child(-n+3) {  display: block;}

  就是这么容易。

 对图标使用SVG

  我们没有理由不对图标使用SVG:

.logo {  background: url("logo.svg");}

  SVG对所有的分辨率类型都具有良好的扩展性,并支持所有浏览器都回归到IE9。这样可以避开.png、.jpg或.gif文件了。

 优化显示文本

  有时,字体并不能在所有设备上都达到最佳的显示,所以可以让设备浏览器来帮助你:

html {  -moz-osx-font-smoothing: grayscale;  -webkit-font-smoothing: antialiased;  text-rendering: optimizeLegibility;}

  注:请负责任地使用 optimizeLegibility。此外,IE /Edge没有 text-rendering 支持。

 对纯CSS滑块使用 max-height

  使用 max-height 和溢出隐藏来实现只有CSS的滑块:

.slider ul {  max-height: 0;  overlow: hidden;}.slider:hover ul {  max-height: 1000px;  transition: .3s ease;}

 继承 box-sizing

  让 box-sizing 继承 html:

html {  box-sizing: border-box;}*, *:before, *:after {  box-sizing: inherit;}

  这样在插件或杠杆其他行为的其他组件中就能更容易地改变 box-sizing 了。

 表格单元格等宽

  表格工作起来很麻烦,所以务必尽量使用 table-layout: fixed 来保持单元格的等宽:

.calendar {  table-layout: fixed;}

 用Flexbox摆脱外边距的各种hack

  当需要用到列分隔符时,通过flexbox的 space-between 属性,你就可以摆脱nth-,first-,和 last-child 的hack了:

.list {  display: flex;  justify-content: space-between;}.list .person {  flex-basis: 23%;}

  现在,列表分隔符就会在均匀间隔的位置出现。

 使用属性选择器用于空链接

  当 <a> 元素没有文本值,但 href 属性有链接的时候显示链接:

a[href^="http"]:empty::before {  content: attr(href);}


0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 孕妇吃了酸梅粉怎么办 婧氏牙膏没客源怎么办 乐视手机耗电快怎么办 乐视手机费电快怎么办 最爱最恨都是你怎么办 耳朵长疱疹很痛怎么办 刚怀孕就有霉菌怎么办 车牌选错了想换怎么办 足癣传染到身上怎么办 金鱼生病了立鳞怎么办 脸上有闭口痘痘怎么办 泰迪得了皮肤癣怎么办 qq截图发不出去怎么办 半夜2点肚子饿怎么办 半夜两三点饿了怎么办 科目三预约不上怎么办 心脏支架又堵了怎么办 车辆验车过期了怎么办 车辆年审过期2天怎么办 违停单子丢了怎么办 沙发弹簧包坏了怎么办 bt种子被和谐了怎么办 苹果手机id密码忘了怎么办 墙漆颜色太深了怎么办 油漆颜色太深了怎么办 墙面漆颜色太深怎么办 古代打仗牙掉了怎么办 乐视电视没声音怎么办 老公疑心病很重怎么办啊 被安装了尿道锁怎么办 狼青小狗腿罗圈怎么办 备孕期间有霉菌怎么办 虫子进皮肤里了怎么办 生完孩子肚子越来越大怎么办 怀孕8个月肚子小怎么办 孕晚期胎儿不长怎么办 肚子上肉特别多怎么办 奶堵了有硬块怎么办 便秘5天肚子胀怎么办 上火大便拉不出来怎么办 大便拉不出来肚子痛怎么办