作为前端,在工作中难免会遇到关于排版的问题,以下是我整理的一些关于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. 运行git提示xcrun: error: invalid active developer path错误

    运行git提示xcrun: error: invalid active developer path错误 是xcode的原因 运行如下命令解决: xcode-select --install

  2. 利用python定位网页上的元素

    1. 想对网页上的元素进行操作,首先需要定位到元素. 以百度首页为例: 输入以下代码,打开百度首页: # coding = gbk from selenium import webdriver chr ...

  3. 牛客小白月赛6 F 发电 树状数组单点更新 求区间乘积 模板

    链接:https://www.nowcoder.com/acm/contest/136/F来源:牛客网  HA实验是一个生产.提炼“神力水晶”的秘密军事基地,神力水晶可以让机器的工作效率成倍提升.   ...

  4. Kubernetes集群部署核心步骤

    目录 前言 一.所有节点安装docker 二.所有节点安装kubeadm 三.安装master节点 四.部署网络插件 五.安装node节点 六.运行一个demo 前言 这里使用环境:Ubuntu 18 ...

  5. 解决问题:SpringMvc中转发的html文件中文是乱码

    目录 1.环境说明,以及前言 2.问题描述: 3.失败的方法(这里写失败并不代表在其他情况不管用) 3.1 html网页本身编码不是UTF-8(推荐尝试) 3.2 web.xml中没有设置配置编码方式 ...

  6. WPF 字体图标样式

    1.在网上下载Font ICO 字体字体压缩包 Font Awesome 矢量图标库    2.下载到的压缩包,解压后获得图标字体文件        3.然后把字体文件夹拷贝到项目中,目录为(/fon ...

  7. 【Offer】[46] 【把数字翻译成字符串】

    题目描述 思路分析 测试用例 Java代码 代码链接 题目描述 给定一个数字,我们按照如下规则把它翻译为字符串: 0翻译成"a",1翻译成"b",..... 1 ...

  8. 解锁HMC8及HMC9的root用户

    某天需要用HMC的root用户干点“坏事”,发现找了一圈都没有正确的HMC v8及v9的root用户破解教程,然后自己研究了一下,发现可以用root用户了.本文测试用的HMC以VMware works ...

  9. JavaScript 基础入门

    JavaScript 基础入门   JavaScript 的组成 JS 由三部分组成,它们分别是:ECMAScript.DOM.BOM. ECMAScript     因为网景开发了JavaScrip ...

  10. 【转载】pandas中的循环

    原始文章链接: https://towardsdatascience.com/how-to-make-your-pandas-loop-71-803-times-faster-805030df4f06 ...