你应该知道的简单易用的CSS技巧
作为前端,在工作中难免会遇到关于排版的问题,以下是我整理的一些关于CSS的技巧,希望对你能有帮助。
1、每个单词的首字母大写
一般我们会用JS实现,其实CSS就可以实现。
JS代码:
var str = 'hello world';
str.replace(/( |^)[a-z]/g,(L)=>L.toUpperCase()
Heool World
css实现:
text-transform:capitalize; ( 文本中每个单词以大写字母开头)
text-transform的属性值有:
uppercase (全部大写)
lowercase (全部小写)
capitalize (首字母大写)
none (默认)
2、元素选中高亮
如input元素:
input:checked + .check {
color:red;
}
3、相邻元素添加边框
有时候我们给元素设置border-top的时候,并不想给第一个元素设置
li+li {
border-top: 1px solid red;
}
4、多列等高
display:table;
5、清除浮动的影响
display:flow-root;
6、input的size属性
在input的type类型为text/password时,size的属性值代表input可容纳的字符的个数,除此之外size 属性会告诉用户端其初始宽度,宽度以 ‘px’ 的形式给出
7、position的粘粘属性
position的属性大家常见的应该就是absolute、fixed、static
为大家介绍一个新的属性 sticky
position:sticky; 设置sticky的同时给元素一个(top,botton,left,right)即可使用
使用条件:
1、父元素不能overflow:hidden 或者 overflow:auto
2、必须指定 top、bottom、left、right
3、父元素的高度不能低于sticky元素的搞丢
4、sticky元素仅在其父元素内生效
8、快速重置表单元素
原始的button按钮要重置挺麻烦的,要设置好几个属性
button {
background: none;
border: none;
color: inherit;
font: inherit;
outline: none;
padding: 0;
}
其实值需要设置
button {
all:unset;
}
9、文本省略号显示
文本省略号,相信大家都很常用
这是不折行的情况
div {
white-space:nowrap;/* 规定文本是否折行 */
overflow: hidden;/* 规定超出内容宽度的元素隐藏 */
text-overflow: ellipsis;
/* 规定超出的内容文本省略号显示,通常跟上面的属性连用,因为没有上面的属性不会触发超出规定的内容 */
}
折行
div {
overflow: hidden;
text-overflow: ellipsis;
display: -webkit-box; /* 将对象作为弹性伸缩盒子模型显示 */
-webkit-line-clamp: 4; /* 控制最多显示几行 */
-webkit-box-orient: vertical; /* 设置或检索伸缩盒对象的子元素的排列方式 */
}
10、设置文本两端对齐
div {
width: 100px;
padding: 0 10px;
background: pink;
margin-bottom: 10px;
text-align-last:justify; /* 关键属性 */
}
11、给元素添加行高
当给元素添加行高我们需要分别添加到每一个元素上p、h,但是其实我们直接添加到body上就可以了
body {
line-height:1;
}
12、 css首字放大
p:first-letter{
display:block;
float:left;
margin: 5px 5px 0 0;
color:red;
font-size:1.4rem;
background:#ddd;
}
13、移除被点击链接的点框
a{
outline:none 或者 outline:0
}
14、计算属性值
div {
width:calc(100%-100px) 让宽度为100%的减去100px
}
15、内容可编辑
<ul contenteditable="true">
<li>11111111 </li>
<li>2222222</li>
<li>3333333</li>
</ul>
16、隐藏文本的两种方法
p{
font-size:0;
}
p{
text-indent:-1000;
}
17、图片在指定尺寸后,如何保持比例
img {
object-fit:cover; 或者 contain
}
18、背景虚化
div {
filter:blur(2px)
}
19、设置宽度
div {
width:fill-available; // 等同于block
}
div {
width:fill-content; // 等同于inline-block
}
20、link状态设置顺序
link的四种状态,需要按照下面的前后顺序来设置
a:link a:visited a:hover a:active
21、font-size基准
浏览器的缺省字体大小是16px,你可以先将基准字体大小设为10px:
body {font-size:62.5%;}
后面统一采用em作为字体单位,2.4em就表示24px。
h1 {font-size: 2.4 em}
22、用图片充当标志
默认情况下,浏览器会用黑圈来充当列表标志,你可以用图片代替
ul li {
background-image: url("path-to-your-image");
background-repeat: none;
background-position: 0 0.5em;
}
23、取消IE的文本滚动
textarea { overflow: auto; }
24、 黑白图像
这会让你的彩色照片变成黑白的图像
img.desaturate {
filter: grayscale(100%);
-webkit-filter: grayscale(100%);
-moz-filter: grayscale(100%);
-ms-filter: grayscale(100%);
-o-filter: grayscale(100%);
}
25、使用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;}
26、禁用鼠标点击
css3属性,当一个元素设置之后将无法点击
.disabled { pointer-events: none; }
27、模糊文本
.blur {
color: transparent;
text-shadow: 0 0 5px rgba(0,0,0,0.5);
}
28、禁止用户选中文本
div {user-select: none; /* Standard syntax */}
你应该知道的简单易用的CSS技巧的更多相关文章
- FineBI:一个简单易用的自助BI工具
过去,有关企业数据分析的重担都压在IT部门,传统BI分析更多面向的是具有IT背景的人员.但随着业务分析需求的增加,很多公司都希望为业务用户提供自助分析服务,将分析工作落实到业务人员手中.但同时,分析工 ...
- DataAccess通用数据库访问类,简单易用,功能强悍
以下是我编写的DataAccess通用数据库访问类,简单易用,支持:内联式创建多个参数.支持多事务提交.支持参数复用.支持更换数据库类型,希望能帮到大家,若需支持查出来后转换成实体,可以自行扩展dat ...
- 快速上手seajs——简单易用Seajs
快速上手seajs——简单易用Seajs 原文 http://www.cnblogs.com/xjchenhao/p/4021775.html 主题 SeaJS 简易手册 http://yslo ...
- [.net 面向对象程序设计进阶] (22) 团队开发利器(一)简单易用的代码管理工具VSS
[.net 面向对象程序设计进阶] (22) 团队开发利器(一)简单易用的代码管理工具VSS 本篇要点:在进阶篇快要结束的时候说说源代码管理器,我们的开发,不是一个人可以完成的事,团队协作很重要,而且 ...
- 设计与开发一款简单易用的Web报表工具(支持常用关系数据及hadoop、hbase等)
EasyReport是一个简单易用的Web报表工具(支持Hadoop,HBase及各种关系型数据库),它的主要功能是把SQL语句查询出的行列结构转换成HTML表格(Table),并支持表格的跨行(Ro ...
- 分享一个简单易用的RPC开源项目—Tatala
http://zijan.iteye.com/blog/2041894 这个项目最早(2008年)是用于一个网络游戏的Cache Server,以及一个电子商务的Web Session服务.后来不断增 ...
- ZOOM - 简单易用的 jQuery 照片相册插件
jQuery 最令人印象深刻的应用之一就是对图片的处理,它可以让帮助你在你的项目中加入一些让人惊叹的图片切换效果.ZOOM 是一款全屏效果的 jQuery 图片切换展示插件,支持键盘前后按键切换,支持 ...
- BasicModal - 简单易用的现代 Web App 弹窗
BasicModal 是为现代 Web 应用程序打造的弹窗系统.它包括所有你需要显示的信息,问题或接收用户的输入.这里的弹窗还可以链接起来,所以你可以很容易地建立一个预定义顺序的安装帮助或显示对话框. ...
- PNotify – 简单易用的 JS 通知,消息提示插件
PNotify 是一个 JavaScript 通知插件,前身为 Pines Notify.它旨在提供无与伦比的灵活性,同时很容易使用.它可以提供无阻塞的通知,允许用户无需关闭通知或者提示信息就可以点击 ...
随机推荐
- HDU 5973 Aninteresting game 威佐夫博奕(Wythoff Game)
HDU 5973:http://acm.hdu.edu.cn/showproblem.php?pid=5975 题意: 有两堆石子,每次可以从一堆石子中取任意个,或者从两堆石子中取相同个数的石子.两个 ...
- UVA - 10480 Sabotage 最小割,输出割法
UVA - 10480 Sabotage 题意:现在有n个城市,m条路,现在要把整个图分成2部分,编号1,2的城市分成在一部分中,拆开每条路都需要花费,现在问达成目标的花费最少要隔开那几条路. 题解: ...
- D-query
SPOJ - DQUERY 题意 求区间内出现一共有几种数字. 上次写了一个主席树,这次用一下莫队,莫队是离线询问的一种操作,将询问分块,如果在同一个块内就按照右端点排序,如果不在同一个块内就按照块的 ...
- hdu 5945 Fxx and game(dp+单调队列! bc#89)
Young theoretical computer scientist Fxx designed a game for his students. In each game, you will ge ...
- java8函数式接口详解、函数接口详解、lambda表达式匿名函数、方法引用使用含义、函数式接口实例、如何定义函数式接口
函数式接口详细定义 函数式接口只有一个抽象方法 由于default方法有一个实现,所以他们不是抽象的. 如果一个接口定义了一个抽象方法,而他恰好覆盖了Object的public方法,仍旧不算做接口的抽 ...
- Net基础篇_学习笔记_第十一天_面向对象(关键字new和this)
new关键字 new:用来创建对象的.Person zsPerson=new Person();new帮助我们做了3件事儿:1).在内存中开辟一块空间2).在开辟的空间中创建对象3).调用对象的构造 ...
- JAVASSM框架面试题
1.SpringMVC的工作流程? 1. 用户发送请求至前端控制器DispatcherServlet 2. DispatcherServlet收到请求调用HandlerMapping处理器映射器. 3 ...
- NOIP2006 1.明明的随机数
题目:明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(N≤100),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不 ...
- Hive数据导入/导出
1.1 导入/导出规则 EXPORT 命令导出数据表或分区,与元数据一起输出到指定位置.又可以从这个输出位置移动到不同的Hadoop 或Hive 实例中,并且使用IMPORT 命令导入. 当导出一个分 ...
- HIve实战分析Hadoop的日志
1.日志格式分析首先分析 Hadoop 的日志格式, 日志是一行一条, 日志格式可以依次描述为:日期.时间.级别.相关类和提示信息.如下所示: -03-06 15:23:48,132 INFO org ...