个人收集的CSS技巧(一)

开个坑…写点平时积累、收集到的CSS技巧吧(半娱乐向)
考虑到IE8等更为古老的浏览器渐渐退出舞台
文中所记录的技巧更偏向于更新、更高级的CSS特性
关于某些属性在浏览器兼容方面的情况,可以浏览caniuse.com


文字模糊效果

p {
   color: transparent;
   text-shadow: 0 0 5px #000;
}

给文字一个透明的颜色,然后依靠黑色阴影来给出一种模糊,存在残影的感觉,效果很赞,关键代码很简单。修改text-shadow属性的第三个参数,可以设置残影的模糊度。

让鼠标指针消失(一般没什么卵用的恶搞)

*{
  cursor: none !important;
}

这个属性很多人都知道,没什么技术含量……但是拿来恶搞一下还是不错的~~

:empty选择器

li {
  padding: 20px;
  background-color: #ccc;
}
li:empty {
  display: none;
}

<ul>
  <li>这里有文字</li>
  <li></li>
  <li>asdfasdf</li>
</ul>

做网页的时候经常有这种情况。有的标签里面文字为空,但是这个标签被应用上特定的样式,即便文字为空还是会展现出来。如果想要避免这种情况。你可以尝试使用CSS3的选择器:empty

菱形图片与裁切路径

假设要用css来实现以下的效果,大家会想怎样的办法?


菱形图片

大部分人的想法应该是用一个div把图片包裹起来。然后将外侧的div顺时针旋转45度,但图片也会跟着外侧的div旋转,这不是我们想要的结果。于是我们只好再将图片逆时针旋转45度。这样图片看起来就正常了。不过还有一个问题在于,旋转过后,图片的宽度理应要等于外侧div对角线的长度,也就是要乘以√2,所以我们将图片再放大√2倍。根据上述思维,我们得到了以下代码:

  .picture {
      width: 400px;
      transform: rotate(45deg);
      overflow: hidden;
  }
  .picture > img {
      width: 100%;
      transform: rotate(-45deg) scale(1.42);
  }

  <div class="picture">
    <img src="xxx.jpg">
  </div>

以上方案的实现稍微有点复杂。而且存在以下缺点:

  1. 难以处理非正方形图片
  2. 需要额外的HTML元素(上例中的div)
  3. 代码量较大

接下来看看另一种基于裁切路径(clip-path)实现的方案。

img {
    clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
}

这个方案相比方案1看起来愉悦了不少。但是……浏览器兼容性就比较惨了……


clip-path兼容性

IE全部不支持,android4.4以前的浏览器也完全不支持,其它浏览器上可能也或多或少存在些问题。不过这个方法真的非常简洁,而且可以很好地适应非正方形的图片。
关于clip-path的更多信息,可以参考MDN上的文档。clip-path属性介绍

背景动画效果

使用线性渐变background-position来进行背景动画的处理。

div {
  width: 300px;
  height: 200px;
  background-image: linear-gradient(#ccc, #000, aqua);
  background-size: auto 200%;
  background-position: 0 100%;
  transition: all 0.5s;
}

div:hover {
  background-position: 0 0;
}

calc属性

在网页布局的过程中,我们经常会用到百分比这一属性。但是不同的设备分辨率不同,同样是100%的宽度自然就可能对应不同的px。假设有一个需求,需要设置一个元素为屏幕宽度的50%+20px。面对此问题,往往需要借助js来完成这一需求。
为了解决这种情况,calc闪亮登场啦。

div {
  width: calc(50% + 20px);
  height: calc(50px + 10em - 2rem);
}

calc支持百分比和px、em的混合运算,能给我们提供许多的便利。这边着重注意下,运算符号和长宽数值要有空格隔开
浏览器支持情况可以参考caniuse
在安卓上的支持还是有点捉急啊…毕竟android4.x的用户还是有一定数量的…

vh与vw

div {
  width: 10vw;
  height: 15vh;
}

vw和vh都是相对viewport的。1vw等于视窗宽度的1%,1vh等于视窗高度的1%。
个人感觉vh的实用性还是蛮不错的。因为在使用css布局的时候,高度和百分比结合的情况相对会麻烦点。

其实还有一种rem布局的方案,就是通过设置根元素的font-size,让一个rem的宽度固定等于屏幕宽度的一定比例,如1rem=10%屏幕宽度。然后用rem来作为元素宽、高的计量单位。
其实最近新出的微信小程序,布局中有一个叫做rpx的东西。思想和rem布局就十分类似。
无非是1rpx = 屏幕宽度 / 750

最后看下兼容吧vw兼容性
老安卓4.3还是不支持

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,737评论 1 92
  • 其实CSS中的长度单位一共有8个,分别是px,em,pt,ex,pc,in,mm,cm。(ex:相对长度单位。相对...
    iam梦的的阅读 489评论 0 0
  • 1.块级元素和行内元素 块级(block-level)元素;行内(内联、inline-level)元素。 块元素的...
    饥人谷_小侯阅读 1,991评论 1 4
  • 赶上拥挤的班车来到这里,已是晌午时分,小憩过后,走上街去,我遇见了黄昏中的乌镇。 西栅,初闻便觉奇怪,恰如想象中黛...
    si宇阅读 637评论 13 9
  • 1. 朋友亚林有一段时间,工作压力特别大,手头项目多,老板盯得紧,那段时间天天加班,每天还患得患失,虽然勤勉认...
    鹿小其阅读 332评论 1 0