css忘了,26个常用易忘CSS小技巧

收集于平时常用但易忘的CSS实现方法,如有遗漏或补充,还请指正!

解决inline-block元素设置overflow:hidden属性导致相邻行内元素向下偏移

.wrap {

display: inline-block;

overflow: hidden

vertical-align: bottom

}

复制代码超出部分显示省略号

// 单行文本

.wrap {

overflow:hidden;/*超出部分隐藏*/

text-overflow:ellipsis;/*超出部分显示省略号*/

white-space:nowrap;/*规定段落中的文本不进行换行 */

}

// 多行文本

.wrap {

width: 100%;

overflow: hidden;

display: -webkit-box; //将对象作为弹性伸缩盒子模型显示 *必须结合的属性*

-webkit-box-orient: vertical; //设置伸缩盒对象的子元素的排列方式 *必须结合的属性*

-webkit-line-clamp: 3; //用来限制在一个块元素中显示的文本的行数

word-break: break-all; //让浏览器实现在任意位置的换行 *break-all为允许在单词内换行*

}

复制代码css实现不换行、自动换行、强制换行

//不换行

.wrap {

white-space:nowrap;

}

//自动换行

.wrap {

word-wrap: break-word;

word-break: normal;

}

//强制换行

.wrap {

word-break:break-all;

}

复制代码CSS实现文本两端对齐

.wrap {

text-align: justify;

text-justify: distribute-all-lines; //ie6-8

text-align-last: justify; //一个块或行的最后一行对齐方式

-moz-text-align-last: justify;

-webkit-text-align-last: justify;

}

复制代码实现文字竖向排版

// 单列展示时

.wrap {

width: 25px;

line-height: 18px;

height: auto;

font-size: 12px;

padding: 8px 5px;

word-wrap: break-word;/*英文的时候需要加上这句,自动换行*/

}

// 多列展示时

.wrap {

height: 210px;

line-height: 30px;

text-align: justify;

writing-mode: vertical-lr; //从左向右

writing-mode: tb-lr; //IE从左向右

//writing-mode: vertical-rl; -- 从右向左

//writing-mode: tb-rl; -- 从右向左

}

复制代码使元素鼠标事件失效

.wrap {

// 如果按tab能选中该元素,如button,然后按回车还是能执行对应的事件,如click。

pointer-events: none;

cursor: default;

}

复制代码禁止用户选择

.wrap {

-webkit-touch-callout: none;

-webkit-user-select: none;

-khtml-user-select: none;

-moz-user-select: none;

-ms-user-select: none;

user-select: none;

}

复制代码cursor属性

.wrap {

cursor:pointer; //小手指;

cursor:help; //箭头加问号;

cursor:wait; //转圈圈;

cursor:move; //移动光标;

cursor:crosshair; //十字光标

}

复制代码使用硬件加速

.wrap {

transform: translateZ(0);

}

复制代码图片宽度自适应

img {max-width: 100%}

复制代码Text-transform和Font Variant

p {text-transform: uppercase} // 将所有字母变成大写字母

p {text-transform: lowercase} // 将所有字母变成小写字母

p {text-transform: capitalize} // 首字母大写

p {font-variant: small-caps} // 将字体变成小型的大写字母

复制代码将一个容器设为透明

.wrap {

filter:alpha(opacity=50);

-moz-opacity:0.5;

-khtml-opacity: 0.5;

opacity: 0.5;

}

复制代码消除transition闪屏

.wrap {

-webkit-transform-style: preserve-3d;

-webkit-backface-visibility: hidden;

-webkit-perspective: 1000;

}

复制代码自定义滚动条

overflow-y: scroll;

整个滚动条

::-webkit-scrollbar {

width: 5px;

}

滚动条的轨道

::-webkit-scrollbar-track {

background-color: #ffa336;

border-radius: 5px;

}

滚动条的滑块

::-webkit-scrollbar-thumb {

background-color: #ffc076;

border-radius: 5px;

}

复制代码让 HTML 识别 string 里的 '\n' 并换行

body {

white-space: pre-line;

}

复制代码实现一个三角形

.wrap {

border-color: transparent transparent green transparent;

border-style: solid;

border-width: 0px 300px 300px 300px;

height: 0px;

width: 0px;

}

复制代码移除被点链接的边框

a {outline: none}

a {outline: 0}

复制代码使用CSS显示链接之后的URL

a:after{content:" (" attr(href) ") ";}

复制代码select内容居中显示、下拉内容右对齐

select{

text-align: center;

text-align-last: center;

}

select option {

direction: rtl;

}

复制代码修改input输入框中光标的颜色不改变字体的颜色

input{

color: #fff;

caret-color: red;

}

复制代码修改input 输入框中 placeholder 默认字体样式

//webkit内核的浏览器

input::-webkit-input-placeholder {

color: #c2c6ce;

}

//Firefox版本4-18

input:-moz-placeholder {

color: #c2c6ce;

}

//Firefox版本19+

input::-moz-placeholder {

color: #c2c6ce;

}

//IE浏览器

input:-ms-input-placeholder {

color: #c2c6ce;

}

复制代码子元素固定宽度 父元素宽度被撑开

// 父元素下的子元素是行内元素

.wrap {

white-space: nowrap;

}

// 若父元素下的子元素是块级元素

.wrap {

white-space: nowrap; // 子元素不被换行

display: inline-block;

}

复制代码让div里的图片和文字同时上下居中

.wrap {

height: 100,

line-height: 100

}

img {

vertival-align:middle

}

// vertical-align css的属性vertical-align用来指定行内元素(inline)或表格单元格(table-cell)元素的垂直对齐方式。只对行内元素、表格单元格元素生效,不能用它垂直对齐块级元素

// vertical-align:baseline/top/middle/bottom/sub/text-top;

复制代码实现宽高等比例自适应矩形

.scale {

width: 100%;

padding-bottom: 56.25%;

height: 0;

position: relative;

}

.item {

position: absolute;

width: 100%;

height: 100%;

background-color: 499e56;

}

这里是所有子元素的容器

复制代码transfrom的rotate属性在span标签下失效

span {

display: inline-block

}

复制代码边框字体同色

.wrap {

width: 200px;

height: 200px;

color: #000;

font-size: 30px;

border: 50px solid currentColor;

// border: 50px solid; // 实现二

}

复制代码

最后

原文在这里:gitHub 如有遗漏,还请指正!!

如果觉得对您有帮助!请别忘记点个赞或者关注哦!您的关注将是我前进的动力!!冲鸭!!!

「无畏前端」不定时更新社区优秀技术文章!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值