单行文本截断

.text{
width: 200px;
text-overflow: ellipsis;
white-space: nowrap;
overflow: hidden;
}

多行文本截断

-webkit-line-clamp属性值为需要截断的行数
.text{
display: -webkit-box;
-webkit-line-clamp:;
-webkit-box-orient: vertical ;
overflow: hidden;
}

:not() 选择器

选中不在此范围内的元素,例如:div:not(:last-child),选中除最后一个div的所有div元素

有时候在做列表时需要为每项添加下边框线,但最后一个项不需要边框线

.item:not(:last-child){
border-bottom: 1px solid #ddd;
}

阻止元素成为鼠标事件的target

pointer-events 指定鼠标如何与元素进行交互,设置为none,阻止任何鼠标事件对其的作用

.item{
pointer-events: none;
}

设置行高,文字顶部对齐

vertical-align 用来指定行内元素(inline)或 表格单元格(table-cell)元素的垂直对齐方式。

子元素设置line-height:1,为了不继承父元素的行高

<p>
<span>顶部对齐</span>
</p>
p{
line-height:;
}
span{
line-height:1;
vertical-align:top;
}

vue深度选择器

有时候需要在组件中局部修改第三方组件的样式,而又不想去除scoped属性造成组件之间的样式污染。

此时只能通过>>>,穿透scoped。

有些Sass 之类的预处理器无法正确解析 >>>。可以使用 /deep/ 操作符 或 ::v-deep( >>> 的别名)

<style scoped>

外层 >>> 第三方组件类名 {
样式
} /deep/ 第三方组件类名 {
样式
} </style>

高宽等比例自适应正方形

当宽度设置为一些自适应的值时(%、vw等),高度的值无法确定,这时可以使用 padding-top:100% 来解决高度的问题,因为 padding 的值参照于 width

<div class="parent">
<div class="child">
这里是内容
</div>
</div>
.parent{
position: relative;
width: 50vw;
height:;
padding-top: 100%;
}
.child{
position: absolute;
width: 100%;
height: 100%;
}

改变input元素光标颜色

input{
caret-color: #dd3131;
}

不规则投影

一般投影效果都会使用box-shadow来完成,但在一些不规则的形状下达不到预想的效果,这时可以使用drop-shadow来完成。

div{
filter: drop-shadow( 6px #ddd);
}

ios移动端滚动卡顿

在ios端中滚动容器不会有惯性滚动,用户在滑动时会出现明显的卡顿感,添加以下属性可解决问题

-webkit-overflow-scrolling: touch;

列表最后一行左对齐

.list {
display: grid;
justify-content: space-between;
grid-template-columns: repeat(auto-fill, 100px);
grid-gap: 10px;
}
.item{
width: 100px;
background: skyblue;
}

@supports特性查询

检测浏览器是否支持CSS的属性值,通过则应用代码块

.box{
width: 100px;
height: 100px;
background: skyblue;
}
@supports (display: grid) {
.box{
background: slateblue;
}
}
/* 两个属性支持即通过,类比 && */
@supports (display: grid) and (display: flex) {
/* css style */
}
/* 其中一个属性支持即通过,类比 || */
@supports (display: grid) or (display: flex) {
/* css style */
}
/* 该属性不支持即通过,类比 ! */
@supports not (display: grid) {
/* css style */
}

查看兼容性:https://www.caniuse.com/#search=%40supports

活动锚点选择器(:target)

地址栏后面跟有锚名称 #,指向文档内某个具体的元素。比如,地址为 loacalhost:3000#red,则选择中ID属性值为red的元素,可以应用到网页换肤功能中。

<style>
div{
display: inline-block;
width: 200px;
height: 200px;
}
#red:target{
background: lightpink;
}
#blue:target{
background: lightblue;
}
</style>
<body>
<div id="red">
<span>红色</span>
</div>
<div id="blue">
<span>蓝色</span>
</div>
<p>
<a href="#red">红色</a>
<a href="#blue">蓝色</a>
</p>
</body>

outline-offset 实现加号图标

想要实现加号需要符合以下几点:

1.容器是个正方形
2.outline 边框的尺寸不能太小
3.outline-offset 的取值范围: -(容器宽度的一半 + outline宽度的一半) < x < -(容器宽度的一半 + outline宽度)

.plus {
width: 100px;
height: 100px;
background: #f4f4f4;
outline: 50px solid #333;
outline-offset: -99px;
}

mask属性

 

mask-image的图片一定要是png图片才看得出效果,两张图片结合会取相交的区域显示,如果用过ps的话,和蒙版是差不多的功能。

mask和background差不多,同样拥有size、repeat、position等属性。

除了IE不支持外,谷歌、火狐、Edge、Safari、Opera等主流的浏览器都支持该属性。

更多属性:https://developer.mozilla.org/en-US/docs/Web/CSS/mask

兼容性:https://www.caniuse.com/#search=mask-image

.mask{
width: 100%;
height: 600px;
background-image: url(../static/images/bg.jpg);
-webkit-mask-image: url(../static/images/pikaqiu.png);
-webkit-mask-size: 300px 300px;
-webkit-mask-repeat: no-repeat;
-webkit-mask-position: 50% 50%;
}

attr函数

attr() 函数返回选择元素的属性值

<p data-unit="km">89</p>
p[data-unit]{
font-size: 20px;
color: #333;
}
p[data-unit]::after{
content: attr(data-unit);
color: #999;
}

currentColor

currentColor不是一个css属性,而是color的属性值,currentColor 返回当前元素继承的文字颜色。

比如当前元素 color 属性值为 red,currentColor 的值也为 red。currentColor相当于color属性值的别名,利用这一特点,我们可以统一管理元素的颜色。

div{
width: 100px;
height: 100px;
color: red;
border: 1px solid currentColor;
}

selection

::selection伪元素应用于文档中被用户选中的部分

<div class="demo">我是一段很长很长很长很长很长很长长很长很长长很长很长的文字</div>
.demo::selection{
background: purple;
color: #fff;
}

一根细线

高度为1px的伪元素,利用背景渐变可以得到比1px更细的边线

.comment-bar::after{
content: '';
position: absolute;
top:;
left:;
width: 100%;
height: 1px;
background: linear-gradient(to bottom, rgba(172,172,172,.3), transparent);
}

两端文本对齐

text-align-last: justify;

以下为 text-align-last 属性值:

  • justify: 两端对齐
  • center: 居中对齐
  • start: 左对齐(也可用left)
  • end: 右对齐(也可用right)

margin排版重轻布局

一个flex布局的列表想要实现左重右轻的布局(即最后一个元素右对齐),可以为最后一个元素添加 margin-left: auto

当然,如果你需要最后两个元素右对齐,只需为倒数第二个加上。

不定时更新~

记录一些实用的小技巧-CSS篇的更多相关文章

  1. 记录一些实用的小技巧-JS篇

    1.16进制随机颜色 let color = '#'+Math.random().toString(16).slice(-6) 2.类型判断工具函数 function isType(target, t ...

  2. scanf和printf格式化输入输出中非常实用的小技巧

    输入输出几乎是每个C程序必须具备的功能,因为有了它们,程序才有了交互性.C提供的输入输出函数除了具有必须的输入输出功能外,还有一些其他实用的小技巧,了解这些小技巧将会为程序带来更友好的用户体验. 一. ...

  3. 哪些window你不知道的却实用的小技巧----window小技巧

    前言 一直想要整理一篇有关于window比较全的使用小技巧,却又不知道从哪里开始写起.而让我准备动手写这边随笔的动力,还是在加入虫部落<一个绿色环保,充满朝气的好地方>,从大家的分享中,我 ...

  4. JavaScript小技巧整理篇(非常全)

    能够为大家提供这些简短而实用的JavaScript技巧来提高大家编程能力,这对于我来说是件很开心的事.每天仅花上不到2分钟的时间中,你将可 以读遍JavaScript这门可怕的语言所呈现给我们的特性: ...

  5. 分享几个 SpringBoot 实用的小技巧

    前言 最近分享的一些源码.框架设计的东西.我发现大家热情不是特别高,想想大多数应该还是正儿八经写代码的居多:这次就分享一点接地气的: SpringBoot 使用中的一些小技巧. 算不上多高大上的东西, ...

  6. Photoshop中比较实用的小技巧

    Photoshop是目前最流行的图片处理软件软件之一.能够说,只要接触图片处理,就要和它打交道.Photoshop的强大功能和众多的优点不用多说.用photoshop做一些漂亮的图片,或对照片进行简单 ...

  7. js的一些实用的小技巧

    1.移动端自适应: 移动端的编写首先需要在header写入以下内容来表示页面是以不缩放的形式展示的: <meta name="viewport" content=" ...

  8. 13个mysql数据库的实用SQL小技巧

    此文章为转载 使用CASE来重新定义数值类型 SELECT id,title, (CASE date WHEN '0000-00-00' THEN '' ELSE date END) AS date ...

  9. vue 项目中实用的小技巧

    # 在Vue 项目中引入Bootstrap 有时在vue项目中会根据需求引入Bootstrap,而Bootstrap又是依赖于jQuery的,在使用npm按照时,可能会出现一系列的错误 1.安装jQu ...

随机推荐

  1. RHEL7-Vsftpd匿名用户

    实现:匿名用户创建目录,可以上传.下载文件,但是不可删除文件,禁止本地用户登陆. Vsftpd.conf部分参数 第一步:虚拟机挂载镜像 略 第二步:执行挂载命令 略 第三步:编写yum仓库文件 略 ...

  2. kubernetes的ingress-nginx

    这是一篇学习记录.记录kubernetes集群中如何将jenkins服务通过域名接入外部.由于是测试环境,域名是自定义的,解析写在/etc/hosts和自己本地的hosts中. 部署图: 一.部署后端 ...

  3. .NET单例模式快速学习应用

    单例模式属于设计模式中最简单的一个模式,在实际应用中也非常广泛,但可能是受到各类教程的影响,看到很多实现方式仍然沿用Java的那一套,其实在.NET中可以用更简洁的实现方式. 一.知识点介绍 核心目标 ...

  4. 树莓派debian配置lamp[解决Apache不显示php网页]

    Apache + MySql + Php. 1.安装Apache Apache可以用下面的命令来安装 sudo apt-get install apache2 Apache默认路径是/var/www/ ...

  5. shell中tar加密打包

    tar 打包是一个很常见的操作,但是当打了一个包却又不想让别人看到里面的小秘密的时候就可以使用加密的方法进行打包. 以下是一个脚本实现的加密打包和解密的shell脚本: cat tar_passwor ...

  6. pat 1011 World Cup Betting(20 分)

    1011 World Cup Betting(20 分) With the 2010 FIFA World Cup running, football fans the world over were ...

  7. nyoj 655-光棍的yy (python, 未A)

    655-光棍的yy 内存限制:64MB 时间限制:1000ms 特判: No 通过数:4 提交数:7 难度:2 题目描述: yy经常遇见一个奇怪的事情,每当他看时间的时候总会看见11:11,这个很纠结 ...

  8. Python3.7.1学习(一):redis的连接和简单使用

    1.python 利用 redis 第三方库 首先安装:pip install redis 2.reids的连接 Redis使用StrictRedis对象来管理对一个redis server 的所有连 ...

  9. Python数据强制类型转换

    本文链接:https://www.cnblogs.com/zyuanlbj/p/11909992.html 常用转换函数 函数 作用 int(x) 将x转换成整数类型 float(x) 将 x 转换成 ...

  10. startup启动不起来关于监听的问题

    问题描述:要在sqlplus中启动到startup状态,但是提示我没有监听,本来以为启动一下就可以,但是connecting to一直卡半天,stop都停止不了 1.发现监听有问题,前去更改 SQL& ...