作为前端,在工作中难免会遇到关于排版的问题,以下是我整理的一些关于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技巧的更多相关文章

  1. FineBI:一个简单易用的自助BI工具

    过去,有关企业数据分析的重担都压在IT部门,传统BI分析更多面向的是具有IT背景的人员.但随着业务分析需求的增加,很多公司都希望为业务用户提供自助分析服务,将分析工作落实到业务人员手中.但同时,分析工 ...

  2. DataAccess通用数据库访问类,简单易用,功能强悍

    以下是我编写的DataAccess通用数据库访问类,简单易用,支持:内联式创建多个参数.支持多事务提交.支持参数复用.支持更换数据库类型,希望能帮到大家,若需支持查出来后转换成实体,可以自行扩展dat ...

  3. 快速上手seajs——简单易用Seajs

    快速上手seajs——简单易用Seajs   原文  http://www.cnblogs.com/xjchenhao/p/4021775.html 主题 SeaJS 简易手册 http://yslo ...

  4. [.net 面向对象程序设计进阶] (22) 团队开发利器(一)简单易用的代码管理工具VSS

    [.net 面向对象程序设计进阶] (22) 团队开发利器(一)简单易用的代码管理工具VSS 本篇要点:在进阶篇快要结束的时候说说源代码管理器,我们的开发,不是一个人可以完成的事,团队协作很重要,而且 ...

  5. 设计与开发一款简单易用的Web报表工具(支持常用关系数据及hadoop、hbase等)

    EasyReport是一个简单易用的Web报表工具(支持Hadoop,HBase及各种关系型数据库),它的主要功能是把SQL语句查询出的行列结构转换成HTML表格(Table),并支持表格的跨行(Ro ...

  6. 分享一个简单易用的RPC开源项目—Tatala

    http://zijan.iteye.com/blog/2041894 这个项目最早(2008年)是用于一个网络游戏的Cache Server,以及一个电子商务的Web Session服务.后来不断增 ...

  7. ZOOM - 简单易用的 jQuery 照片相册插件

    jQuery 最令人印象深刻的应用之一就是对图片的处理,它可以让帮助你在你的项目中加入一些让人惊叹的图片切换效果.ZOOM 是一款全屏效果的 jQuery 图片切换展示插件,支持键盘前后按键切换,支持 ...

  8. BasicModal - 简单易用的现代 Web App 弹窗

    BasicModal 是为现代 Web 应用程序打造的弹窗系统.它包括所有你需要显示的信息,问题或接收用户的输入.这里的弹窗还可以链接起来,所以你可以很容易地建立一个预定义顺序的安装帮助或显示对话框. ...

  9. PNotify – 简单易用的 JS 通知,消息提示插件

    PNotify 是一个 JavaScript 通知插件,前身为 Pines Notify.它旨在提供无与伦比的灵活性,同时很容易使用.它可以提供无阻塞的通知,允许用户无需关闭通知或者提示信息就可以点击 ...

随机推荐

  1. Gym 101470 题解

    A:Banks 代码: #include<bits/stdc++.h> using namespace std; #define Fopen freopen("_in.txt&q ...

  2. 牛客网 Wannafly挑战赛 A 找一找 思考题

    链接:https://www.nowcoder.com/acm/contest/71/A来源:牛客网 题目描述 给定n个正整数,请找出其中有多少个数x满足:在这n个数中存在数y=kx,其中k为大于1的 ...

  3. Flask源码浅析

    前言 学习一样东西,要先知其然,然后知其所以然. 这次,我们看看Flask Web框架的源码.我会以Flask 0.1的源码为例,把重点放在Flask如何处理请求上,看一看从一个请求到来到返回响应都经 ...

  4. 渗透测试----access偏移注入

    偏移注入指access偏移注入,由于数据库结构的问题,偏移注入只适用于access数据库.对于access数据库来说,无论是逐字猜解还是联合查询注入,都是需要我们能够猜到用户名和密码的列名(字段),才 ...

  5. Hive导入数据到HBase,再与Phoenix映射同步

    1. 创建HBase 表 create 'hbase_test','user' 2. 插入数据 put 'hbase_test','111','user:name','jack' put 'hbase ...

  6. BeanFactory not initialized or already closed

    产生这个错误有两个可能, 一.你没有配置初始化文件,在web.xml中配置如下 <context-param> <param-name>contextConfigLocatio ...

  7. python,json解析字符串时ValueError: Expecting property name enclosed in double quotes: line 1 column 2 (char 1)

    今天写测试工具的时候,去excel取数据,用json解析字符串为字典时报错,后经调试,发现是单引号的原因,将单引号换位双引号即可 def getExcelValue_to_dic(filepath): ...

  8. 2018年秋招总结篇(Java)

    博主开始找工作是10月10号,感觉可以出去找找工作,然后就去了,参加了多场面试.笔试,现在总结一下 1.笔试篇 String StringBuffer StringBuilder的区别? HashMa ...

  9. Tomcat 报错 The APR based Apache Tomcat Native library which allows optimal performance in production environmen

    这个问题在我一次重新装了tomcat和myeclipse时出现 说实话 出现这个问题头大 但是好在解决了 美滋滋 最开始到处寻找各种解决方案 最后直接注释了server.xml中的一行 直接解决这个报 ...

  10. 抓住那只牛!Catch That Cow POJ-3278 BFS

    题目链接:Catch That Cow 题目大意 FJ丢了一头牛,FJ在数轴上位置为n的点,牛在数轴上位置为k的点.FJ一分钟能进行以下三种操作:前进一个单位,后退一个单位,或者传送到坐标为当前位置两 ...