CSS 高级技巧汇总分享

本文主要和大家分享CSS 高级技巧汇总,使用技巧会让人变的越来越懒,没错,我就是想让你变懒。下面是我收集的CSS高级技巧,希望你懒出境界。

1. 黑白图像

这段代码会让你的彩色照片显示为黑白照片,是不是很酷?


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

img.desaturate {  filter: grayscale(100%);  -webkit-filter: grayscale(100%);  -moz-filter: grayscale(100%);  -ms-filter: grayscale(100%);  -o-filter: grayscale(100%);}

登录后复制

2. 使用 :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;}

登录后复制

3. 页面顶部阴影

下面这个简单的 CSS3 代码片段可以给网页加上漂亮的顶部阴影效果:


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

body:before {  content: "";  position: fixed;  top: -10px;  left: 0;  width: 100%;  height: 10px;  -webkit-box-shadow: 0px 0px 10px rgba(0,0,0,.8);  -moz-box-shadow: 0px 0px 10px rgba(0,0,0,.8);  box-shadow: 0px 0px 10px rgba(0,0,0,.8);  z-index: 100;}

登录后复制

4. 给 body 添加行高

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


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

body {  line-height: 1;}

登录后复制

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

5. 所有一切都垂直居中

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


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

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

6. 逗号分隔的列表

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


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

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

登录后复制

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

7. 使用负的 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;}

登录后复制

8. 对图标使用 SVG

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


登录后复制登录后复制

.logo {

 background: url(“logo.svg”);

}

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

9. 优化显示文本

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


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

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

登录后复制

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

10. 对纯 CSS 滑块使用 max-height

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


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

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

登录后复制

11. 继承 box-sizing

让 box-sizing 继承 html:


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

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

登录后复制

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

12. 表格单元格等宽

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


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

.calendar {  table-layout: fixed;}

登录后复制

13. 用 Flexbox 摆脱外边距的各种 hack

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


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

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

登录后复制

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

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

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


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

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

登录后复制

相当方便。

15. 检测鼠标双击

HTML:


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

    Double click me

登录后复制

CSS:


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

.test3 span {  position: relative;}.test3 span a {  position: relative;  z-index: 2;}.test3 span a:hover, .test3 span a:active {  z-index: 4;}.test3 span input {  background: transparent;  border: 0;  cursor: pointer;  position: absolute;  top: -1px;  left: 0;  width: 101%;  /* Hacky */  height: 301%; /* Hacky */  z-index: 3;}.test3 span input:focus {  background: transparent;  border: 0;  z-index: 1;}

登录后复制

16. CSS 写出三角形


登录后复制登录后复制

/* create an arrow that points up */p.arrow-up {  width:0px;  height:0px;  border-left:5px solid transparent;  /* left arrow slant */  border-right:5px solid transparent; /* right arrow slant */  border-bottom:5px solid #2f2f2f; /* bottom, add background color here */  font-size:0px;  line-height:0px;}/* create an arrow that points down */p.arrow-down {  width:0px;  height:0px;  border-left:5px solid transparent;  border-right:5px solid transparent;  border-top:5px solid #2f2f2f;  font-size:0px;  line-height:0px;}/* create an arrow that points left */p.arrow-left {  width:0px;  height:0px;  border-bottom:5px solid transparent;  /* left arrow slant */  border-top:5px solid transparent; /* right arrow slant */  border-right:5px solid #2f2f2f; /* bottom, add background color here */  font-size:0px;  line-height:0px;}/* create an arrow that points right */p.arrow-right {  width:0px;  height:0px;  border-bottom:5px solid transparent;  /* left arrow slant */  border-top:5px solid transparent; /* right arrow slant */  border-left:5px solid #2f2f2f; /* bottom, add background color here */  font-size:0px;  line-height:0px;}

登录后复制

17. CSS3 calc() 的使用

calc() 用法类似于函数,能够给元素设置动态的值:


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

/* basic calc */.simpleBlock {  width: calc(100% - 100px);}/* calc in calc */.complexBlock {  width: calc(100% - 50% / 3);  padding: 5px calc(3% - 2px);  margin-left: calc(10% + 10px);}

登录后复制

18. 文本渐变

文本渐变效果很流行,使用 CSS3 能够很简单就实现:


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

h2[data-text] {  position: relative;}h2[data-text]::after {  content: attr(data-text);  z-index: 10;  color: #e3e3e3;  position: absolute;  top: 0;  left: 0;  -webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0,0,0,0)), color-stop(50%, rgba(0,0,0,1)), to(rgba(0,0,0,0)));}

登录后复制

19. 禁用鼠标事件

CSS3 新增的 pointer-events 让你能够禁用元素的鼠标事件,例如,一个连接如果设置了下面的样式就无法点击了。


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

.disabled { pointer-events: none; }

登录后复制

20. 模糊文本

简单但很漂亮的文本模糊效果,简单又好看!


登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制

.blur {   color: transparent;   text-shadow: 0 0 5px rgba(0,0,0,0.5);}

登录后复制

相关推荐:

CSS高级技巧

CSS高级技巧

CSS高级技巧

以上就是CSS 高级技巧汇总分享的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3121018.html

(0)
上一篇 2025年3月29日 17:42:48
下一篇 2025年3月29日 17:42:57

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • CSS3通过@keyframes创建动画

    本文主要和大家介绍了css3 @keyframes简单动画实现的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 定义: 通过 @keyframes 规则,能够创建动画。 创建动画的原…

    编程技术 2025年3月29日
    000
  • css3的旋转木马

    这次给大家带来css3的旋转木马,实现css3旋转木马的注意事项有哪些,下面就是实战案例,一起来看一下。 1、perspective perspective属性包括两个属性:none和具有单位的长度值。 其中perspective属性的默认…

    编程技术 2025年3月29日
    100
  • 如何用css写对联广告代码

    本文章提供的对联广告是完全使用css实现的,并且兼容所有浏览器,包括各种ie,ff,gg浏览器,代码简洁好用。 代码如下: .couplet_ad/* 底部固定*/{position:fixed;bottom:auto; top:0; wi…

    编程技术 2025年3月29日
    100
  • 如何做到不用图片用css实现按钮的美化

    本篇文章主要介绍如何做到不用图片用css实现按钮的美化,感兴趣的小伙伴参考一下。 代码如下:   .tb{width:100%;height:1px;overflow:hidden;background:rgb(250,100,0);mar…

    编程技术 2025年3月29日
    100
  • 一些CSS样式基础知识

    在学习中会遇到一些css基础知识,本篇介绍一些css样式基础知识。 样式有几种引入方式? link 和 @import有什么区别 样式有三种引入方式,分别是: 外部引入式主要是使用link标签或者@import标签从外部引入后缀名为.css…

    编程技术 2025年3月29日
    100
  • 什么是CSS变量?CSS变量的学习:CSS变量的继承&作用域

    CSS变量能帮助我们干什么 在一些命令式编程语言中,像Java、C++亦或是JavaScript,通过变量我们能够跟踪某些状态。变量是一种符号,关联着一个特定的值,变量的值能随着时间的推移而改变。在像CSS这种声明式语言中,随着时间而改变的…

    编程技术 2025年3月29日
    100
  • CSS什么是继承?CSS如何使用?

    本篇文章给大家带来的内容是介绍css什么是继承?css如何使用?有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所助。 CSS的继承 css的继承指的是当标签具有嵌套关系时,内部标签自动拥有外部标签的不冲突的样式的性质。 在Css中…

    编程技术 2025年3月29日
    100
  • CSS选择符是什么?CSS选择符有哪些?

    本篇文章给大家带来的内容是介绍css选择符是什么?css选择符有哪些?有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所助。 W3School离线手册(2017.03.11版)下载:https://pan.baidu.com/s/1…

    编程技术 2025年3月29日
    100
  • css怎么重置样式?网页中8种css默认样式重置代码汇总

    本篇文章给大家带来的内容是介绍css怎么重置样式,总结了一些常用css默认样式重置的代码分享给大家。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 在网页设计开发时,让人最头疼的莫过于让页面兼容各大浏览器,准确些是兼容它们…

    编程技术 2025年3月29日
    100
  • css-theme如何通过源码生成一份包含多套皮肤配置的样式文件

    本篇文章给大家带来的内容是关于css-theme如何通过源码生成一份包含多套皮肤配置的样式文件,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 css-theme 通过单一css文件生成多套主题,并合并入一个css文件中 特…

    编程技术 2025年3月29日
    100

发表回复

登录后才能评论