CSS实用技巧:文字处理

前言

作为程序员的我们,书写代码也需要大量的技巧。一份良好的代码能让人耳目一新,让人容易理解,同时也让自己成就感满满。因此,在这里简单的整理一些CSS开发技巧,希望能让你写出耳目一新、容易理解、舒服自然的代码。

CSS实用技巧:文字处理

CSS实用技巧第一讲:文字处理

本小结主要是围绕css对文字处理的技巧,有兴趣的小伙伴可以收藏一下。

文本对齐方式

CSS最常用的对齐方式,居中对齐、左对齐(默认)、右对齐,而且实现起来也是非常的简单。

如下:

  1. p{  
  2.  text-align: center;  
  3.  text-align: left;  
  4.  text-align: right;  

但是两端对齐你有用过吗?

只需要添加text-align-last:justify样式即可。请看示例:

  1. <div class="justify-text">  
  2.  <div class="li">账号</div>  
  3.  <div class="li">密码</div>  
  4.  <div class="li">电子邮件</div>  
  5. </div> 

scss样式

  1. .justify-text {  
  2.     .li {  
  3.         padding: 0 20px;  
  4.  margin-top: 10px;  
  5.         width: 100px;  
  6.         background-color: #f13f84;  
  7.         line-height: 40px;  
  8.         text-align-last: justify;  
  9.         color: #fff;  
  10.  list-style: none;  
  11.         &:first-child {  
  12.             margin-top: 0;  
  13.         }  
  14.     }  

CSS实用技巧:文字处理

CSS实用技巧第一讲:文字处理

文本排版方向

现代书本上的文字都是从左到右的顺序排列,但是古时候不同,文字都是从右至左排列的,现在在很多古籍、牌坊、石碑等上面依旧可以看到从右至左的文字。

css也可以调整文本排版方向,是通过什么属性控制的呢?

writing-mode 属性定义了文本在水平或垂直方向上如何排布。 

  1. writing-mode: horizontal-tb | vertical-rl | vertical-lr | sideways-rl | sideways-lr 
  •  horizontal-tb:水平方向自上而下的书写方式。即 left-right-top-bottom
  •  vertical-rl:垂直方向自右而左的书写方式。即 top-bottom-right-left
  •  vertical-lr:垂直方向内内容从上到下,水平方向从左到右
  •  sideways-rl:内容垂直方向从上到下排列
  •  sideways-lr:内容垂直方向从下到上排列

下面看具体示例:

  1. <div class="bruce flex-ct-x">  
  2.     <div class="vertical-text">  
  3.         <h3>诗经</h3>  
  4.         <p>  
  5.  死生契阔,<br>  
  6.  与子成说。<br>  
  7.  执子之手,<br>  
  8.  与子偕老。  
  9.  </p>  
  10.     </div>  
  11. </div> 

scss样式

  1. .vertical-text {  
  2.     writing-mode: vertical-rl; // 文字排版方向  
  3.     h3 {  
  4.         padding-left: 10px;  
  5.         font-weight: bold;  
  6.         font-size: 18px;  
  7.         color: #d60f5c;  
  8.     }  
  9.     p {  
  10.         line-height: 30px; // 行间距  
  11.  letter-spacing: 7px; // 文字间距  
  12.         color: #ee1166;  
  13.     }  

CSS实用技巧:文字处理

CSS实用技巧第一讲:文字处理

文本从右至左排列

  1. <div class="reverse-text">  
  2.  红豆生南国<br/>  
  3.  春来发几枝<br/>  
  4.  愿君多采撷<br/>  
  5.  此物最相思  
  6. </div> 

scss样式

  1. .reverse-text {  
  2.     font-weight: bold;  
  3.     font-size: 30px;  
  4.     color: #f13f84;  
  5.  width: 200px;  
  6.     letter-spacing: -70px; // letter-spacing最少是font-size的2倍  

CSS实用技巧:文字处理

CSS实用技巧第一讲:文字处理

文本溢出控制

文本溢出处理不管是PC或者是H5,都是非常常见的,非详情页面都会经常用到。

文本溢出处理分为:单行文字溢出 和 多行文字溢出。下面看看具体示例:

单行文字溢出

  1. <div class="ellipsis">昨夜雨疏风骤,浓睡不消残酒。试问卷帘人,却道海棠依旧。知否,知否,应是绿肥红瘦。</div> 

scss样式

  1. .ellipsis {  
  2.  width: 200px;  
  3.     overflow: hidden; // 溢出隐藏  
  4.     text-overflow: ellipsis; // 溢出修饰 ellipsis省略号  
  5.     white-space: nowrap; // 文本不会换行  

CSS实用技巧:文字处理

CSS实用技巧第一讲:文字处理

多行文字溢出

<div class="ellipsis">寻寻觅觅,冷冷清清,凄凄惨惨戚戚。乍暖还寒时候,最难将息。三杯两盏淡酒,怎敌他、晚来风急!雁过也,正伤心,却是旧时相识。

满地黄花堆积,憔悴损,如今有谁堪摘?守着窗儿,独自怎生得黑!梧桐更兼细雨,到黄昏、点点滴滴。这次第,怎一个愁字了得!</div>

scss样式

  1. .ellipsis {  
  2.  width: 400px;  
  3.     display: -webkit-box;  
  4.     overflow: hidden;  
  5.     text-overflow: ellipsis;  
  6.     -webkit-line-clamp: 3;  
  7.     /* autoprefixer: off */  
  8.     -webkit-box-orient: vertical;  
  9.     /* autoprefixer: on */  

CSS实用技巧:文字处理

CSS实用技巧第一讲:文字处理

注意

使用文本溢出处理时,容器一定要定义宽度。

多行文字溢出,scss样式添加注释autoprefixer: off并不是为了说明什么,而是,在webpack打包编译时,如果没有这个注释,-webkit-box-orient: vertical会被忽略掉。

文本选择颜色

在浏览器中,当你选择文本想要copy时,是不是会发现选择文本会有背景色和文字颜色呢?其实它是可以通过css定义的。

使用::selection自定义文本选择颜色

  1. <div class="select-color">  
  2.  <p>红豆生南国,</p>  
  3.  <p class="special">春来发几枝。</p>  
  4.  <p>愿君多采撷,</p>  
  5.  <p class="special">此物最相思。</p>  
  6. </div> 

scss样式

  1. // 全局文本选择样式  
  2. ::selection {  
  3.     background-color: #f13f84;  
  4.     color: #fff;  
  5.  
  6. .select-color {  
  7.     line-height: 30px;  
  8.     font-weight: bold;  
  9.     font-size: 30px;  
  10.     color: #d60f5c;  
  11.  
  12. // 具体某个选择器下 文本选择样式  
  13. .special::selection {  
  14.     background-color: #00b7a3;  

CSS实用技巧:文字处理

CSS实用技巧第一讲:文字处理

总结

相关推荐