点击右上方红色按钮关注“web秀”,让你真正秀起来
前言
作为程序员的我们,书写代码也需要大量的技巧。一份良好的代码能让人耳目一新,让人容易理解,同时也让自己成就感满满。因此,在这里简单的整理一些CSS开发技巧,希望能让你写出耳目一新、容易理解、舒服自然的代码。
CSS实用技巧第一讲:文字处理
本小结主要是围绕css对文字处理的技巧,有兴趣的小伙伴可以收藏一下。
文本对齐方式
CSS最常用的对齐方式,居中对齐、左对齐(默认)、右对齐,而且实现起来也是非常的简单。
如下:
p{ | |
text-align: center; | |
text-align: left; | |
text-align: right; | |
} |
但是两端对齐你有用过吗?
只需要添加text-align-last:justify样式即可。请看示例:
<div class="justify-text"> | |
<div class="li">账号</div> | |
<div class="li">密码</div> | |
<div class="li">电子邮件</div> | |
</div> |
scss样式
.justify-text { | |
.li { | |
padding: 0 20px; | |
margin-top: 10px; | |
width: 100px; | |
background-color: #f13f84; | |
line-height: 40px; | |
text-align-last: justify; | |
color: #fff; | |
list-style: none; | |
&:first-child { | |
margin-top: 0; | |
} | |
} | |
} |
CSS实用技巧第一讲:文字处理
文本排版方向
现代书本上的文字都是从左到右的顺序排列,但是古时候不同,文字都是从右至左排列的,现在在很多古籍、牌坊、石碑等上面依旧可以看到从右至左的文字。
css也可以调整文本排版方向,是通过什么属性控制的呢?
writing-mode 属性定义了文本在水平或垂直方向上如何排布。
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:内容垂直方向从下到上排列
下面看具体示例:
<div class="bruce flex-ct-x"> | |
<div class="vertical-text"> | |
<h3>诗经</h3> | |
<p> | |
死生契阔,<br> | |
与子成说。<br> | |
执子之手,<br> | |
与子偕老。 | |
</p> | |
</div> | |
</div> |
scss样式
.vertical-text { | |
writing-mode: vertical-rl; // 文字排版方向 | |
h3 { | |
padding-left: 10px; | |
font-weight: bold; | |
font-size: 18px; | |
color: #d60f5c; | |
} | |
p { | |
line-height: 30px; // 行间距 | |
letter-spacing: 7px; // 文字间距 | |
color: #ee1166; | |
} | |
} |
CSS实用技巧第一讲:文字处理
文本从右至左排列
<div class="reverse-text"> | |
红豆生南国<br/> | |
春来发几枝<br/> | |
愿君多采撷<br/> | |
此物最相思 | |
</div> |
scss样式
.reverse-text { | |
font-weight: bold; | |
font-size: 30px; | |
color: #f13f84; | |
width: 200px; | |
letter-spacing: -70px; // letter-spacing最少是font-size的2倍 | |
} |
CSS实用技巧第一讲:文字处理
文本溢出控制
文本溢出处理不管是PC或者是H5,都是非常常见的,非详情页面都会经常用到。
文本溢出处理分为:单行文字溢出 和 多行文字溢出。下面看看具体示例:
单行文字溢出
<div class="ellipsis">昨夜雨疏风骤,浓睡不消残酒。试问卷帘人,却道海棠依旧。知否,知否,应是绿肥红瘦。</div>
scss样式
.ellipsis { | |
width: 200px; | |
overflow: hidden; // 溢出隐藏 | |
text-overflow: ellipsis; // 溢出修饰 ellipsis省略号 | |
white-space: nowrap; // 文本不会换行 | |
} |
CSS实用技巧第一讲:文字处理
多行文字溢出
<div class="ellipsis">寻寻觅觅,冷冷清清,凄凄惨惨戚戚。乍暖还寒时候,最难将息。三杯两盏淡酒,怎敌他、晚来风急!雁过也,正伤心,却是旧时相识。
满地黄花堆积,憔悴损,如今有谁堪摘?守着窗儿,独自怎生得黑!梧桐更兼细雨,到黄昏、点点滴滴。这次第,怎一个愁字了得!</div>
scss样式
.ellipsis { | |
width: 400px; | |
display: -webkit-box; | |
overflow: hidden; | |
text-overflow: ellipsis; | |
-webkit-line-clamp: 3; | |
/* autoprefixer: off */ | |
-webkit-box-orient: vertical; | |
/* autoprefixer: on */ | |
} |
CSS实用技巧第一讲:文字处理
注意
使用文本溢出处理时,容器一定要定义宽度。
多行文字溢出,scss样式添加注释autoprefixer: off并不是为了说明什么,而是,在webpack打包编译时,如果没有这个注释,-webkit-box-orient: vertical会被忽略掉。
文本选择颜色
在浏览器中,当你选择文本想要copy时,是不是会发现选择文本会有背景色和文字颜色呢?其实它是可以通过css定义的。
使用::selection自定义文本选择颜色
<div class="select-color"> | |
<p>红豆生南国,</p> | |
<p class="special">春来发几枝。</p> | |
<p>愿君多采撷,</p> | |
<p class="special">此物最相思。</p> | |
</div> |
scss样式
// 全局文本选择样式 | |
::selection { | |
background-color: #f13f84; | |
color: #fff; | |
} | |
.select-color { | |
line-height: 30px; | |
font-weight: bold; | |
font-size: 30px; | |
color: #d60f5c; | |
} | |
// 具体某个选择器下 文本选择样式 | |
.special::selection { | |
background-color: #00b7a3; | |
} |
CSS实用技巧第一讲:文字处理
总结
有空把CSS3及其选择器和伪元素伪类等知识点复习一遍,温故而知新。多使用Chrome的DevTools来调试CSS,提示式的填值能发现很多有趣的属性。多尝试不同的方式实现相同功能,多实践。项目中多试用CSS的新特性,不要总是被低版本浏览器束缚着,这样也一直难以进步。在使用JS完成一个简单的效果前先想想能不能用纯CSS来完成。这样你的CSS技能就能得到稳步提升。
最后谢谢大家的支持。