No.8 CSS字体属性、文本属性、背景、界面样式

一、CSS字体属性

1.CSS字体系列

CSS 使用 font-family 属性定义文本的字体系列。

p { font-family:"微软雅黑";}
div {font-family: Arial,"Microsoft Yahei", "微软雅黑";}

各种字体之间必须使用英文状态下的逗号隔开;
一般情况下,如果有空格隔开的多个单词组成的字体,加引号;
尽量使用系统默认自带字体,保证在任何用户的浏览器中都能正确显示;
最常见的几个字体:
body {font-family: 'Microsoft YaHei',tahoma,arial,'Hiragino Sans GB'; }

Unicode编码字体:
把中文字体的名称用相应的Unicode编码来代替,这样就可以有效的避免浏览器解释CSS代码时候出现乱码的问题。
比如:
黑体 \9ED1\4F53
宋体 \5B8B\4F53
微软雅黑 \5FAE\8F6F\96C5\9ED1

2.CSS字体大小

CSS 使用 font-size 属性定义字体大小。

p {
    font-size: 20px;
}

px(像素)大小是我们网页的最常用的单位;
谷歌浏览器默认的文字大小为16px;
不同浏览器可能默认显示的字号大小不一致,我们尽量给一个明确值大小,不要默认大小;
可以给 body 指定整个页面文字的大小;

3.CSS字体粗细

CSS 使用 font-weight 属性设置文本字体的粗细。

p {
    font-weight: bold;
}
属性值 描述
normal 不加粗(默认值)
bold 加粗
100~900 400等同于normal,700等同于bold,没有单位

学会让加粗标签(比如 h 和 strong 等) 不加粗,或者其他标签加粗;
实际开发时,我们更喜欢用数字表示粗细。

4.CSS字体样式

CSS 使用 font-style 属性设置文本的风格。

p {
    font-style: normal;
}
属性值 描述
normal 标准的字体样式(默认值)
italic 斜体

平时我们很少给文字加斜体,反而要给斜体标签(em,i)改为不倾斜字体。

5.CSS字体复合属性

字体属性可以把以上文字样式综合来写。

body {
    font: font-style font-weight font-size/line-height font-family;
}

使用 font 属性时,必须按上面语法格式中的顺序书写,不能更换顺序,并且各个属性间以空格隔开;
不需要设置的属性可以省略(取默认值),但必须保留 font-size 和 font-family 属性,否则 font 属性将不起作用;

二、CSS文本属性

1.CSS文本颜色

color 属性用于定义文本的颜色。

div {
    color: red;
}
表示 属性值
预定义的颜色值 red,green,blue
十六进制 #FF0000,#29d83e
RGB代码 rgb(255,0,0),rgb(100%,0%,0%)

开发中最常用的是十六进制。

2.CSS对齐文本

text-align 属性用于设置元素内文本内容的水平对齐方式。

div {
    text-align: center;
}
属性值 描述
left 左对齐(默认值)
right 右对齐
center 居中对齐

3.CSS装饰文本

text-decoration 属性规定添加到文本的修饰。可以给文本添加下划线、删除线、上划线等。

div {
    text-decoration:underline;
}
属性值 描述
none 没有装饰线(默认值)
underline 下划线
overline 上划线
line-through 删除线

4.CSS文本缩进

text-indent 属性用来指定文本的第一行的缩进,通常是将段落的首行缩进。

div {
    text-indent: 10px;
}

通过设置该属性,所有元素的第一行都可以缩进一个给定的长度,甚至该长度可以是负值。

p {
    text-indent: 2em;
}

em 是一个相对单位,就是当前元素(font-size) 1 个文字的大小,如果当前元素没有设置大小,则会按照父元素的 1 个文字大小。

5.CSS行间距

line-height 属性用于设置行间的距离(行高)。可以控制文字行与行之间的距离。

p {
    line-height: 26px;
}
行间距

单行文字垂直居中:
CSS 没有给我们提供文字垂直居中的代码. 这里我们可以使用一个小技巧来实现.
解决方案: 让文字的行高等于盒子的高度,就可以让文字在当前盒子内垂直居中
简单理解: 行高的上空隙和下空隙把文字挤到中间了. 如果行高小于盒子高度,文字会偏上,如果行高大于盒子高度,则文字偏下

6.vertical-align 属性应用

CSS 的 vertical-align 属性使用场景: 经常用于设置图片或者表单(行内块元素)和文字垂直对齐。
官方解释: 用于设置一个元素的垂直对齐方式,但是它只针对于行内元素或者行内块元素有效。
语法:
vertical-align : baseline | top | middle | bottom
baseline默认,元素放置在父元素的基线上;
top把元素的顶端与行中最高元素的顶端对齐;
middle把此元素放置在父元素的中部;
bottom把元素的顶端与行中最低的元素的顶端对齐;


vertical-align

图片、表单都属于行内块元素,默认的 vertical-align 是基线对齐。
此时可以给图片、表单这些行内块元素的 vertical-align 属性设置为 middle 就可以让文字和图片垂直居中对齐了。

图片底侧会有一个空白缝隙,原因是行内块元素会和文字的基线对齐。

主要解决方法有两种:

  1. 给图片添加 vertical-align:middle | top| bottom 等。 (提倡使用的)
  2. 把图片转换为块级元素 display: block;

7.溢出的文字省略号显示

  1. 单行文本溢出显示省略号-必须满足三个条件
  1. 先强制一行内显示文本
    white-space: nowrap; ( 默认 normal 自动换行)
  2. 超出的部分隐藏
    overflow: hidden;
  3. 文字用省略号替代超出的部分
    text-overflow: ellipsis;
  1. 多行文本溢出显示省略号

overflow: hidden;
text-overflow: ellipsis;
弹性伸缩盒子模型显示
display: -webkit-box;
限制在一个块元素显示的文本的行数
-webkit-line-clamp: 2;
设置或检索伸缩盒对象的子元素的排列方式
-webkit-box-orient: vertical;

多行文本溢出显示省略号,有较大兼容性问题, 适合于webKit浏览器或移动端(移动端大部分是webkit内核)。更推荐让后台人员来做这个效果,因为后台人员可以设置显示多少个字,操作更简单。

三、CSS背景

1.CSS背景颜色

background-color 属性定义了元素的背景颜色。
background-color:颜色值;
一般情况下元素背景颜色默认值是 transparent(透明),我们也可以手动指定背景颜色为透明色。

2.CSS背景图片

background-image 属性描述了元素的背景图像。实际开发常见于 logo 或者一些装饰性的小图片或者是超大的背景图片, 优点是非常便于控制位置. (精灵图也是一种运用场景)
background-image : none | url (url);

属性值 描述
none 无背景图(默认值)
url 使用绝对或相对地址指定背景图像

注意:背景图片后面的地址,千万不要忘记加 URL, 同时里面的路径不要加引号。

3.CSS背景平铺

如果需要在 HTML 页面上对背景图像进行平铺,可以使用 background-repeat 属性。
background-repeat: repeat | no-repeat | repeat-x | repeat-y;
repeat:背景图像在纵向和横向上平铺(默认的);
no-repeat:背景图像不平铺;
repeat-x:背景图像在横向上平铺;
repeat-y:背景图像在纵向上平铺;

4.CSS背景图片位置

利用 background-position 属性可以改变图片在背景中的位置。
background-position: x y;
参数代表的意思是:x 坐标和 y 坐标。 可以使用 方位名词 或者 精确单位

参数值 说明
length 百分数,由浮点数字和单位标识符组成的长度值
position 方位名词,top,center,bottom,left,center,right

1)参数是方位名词
如果指定的两个值都是方位名词,则两个值前后顺序无关,比如 left top 和 top left 效果一致
如果只指定了一个方位名词,另一个值省略,则第二个值默认居中对齐
2)参数是精确单位
如果参数值是精确坐标,那么第一个肯定是 x 坐标,第二个一定是 y 坐标
如果只指定一个数值,那该数值一定是 x 坐标,另一个默认垂直居中
3)参数是混合单位
如果指定的两个值是精确单位和方位名词混合使用,则第一个值是 x 坐标,第二个值是 y 坐标

5.CSS背景图像固定(背景附着)

background-attachment 属性设置背景图像是否固定或者随着页面的其余部分滚动。
background-attachment 后期可以制作视差滚动的效果。
background-attachment : scroll | fixed;
scroll:背景图像随对象内容滚动;
fixed:背景图像固定;

5.CSS背景复合写法

为了简化背景属性的代码,我们可以将这些属性合并简写在同一个属性 background 中。从而节约代码量.
当使用简写属性时,没有特定的书写顺序,一般习惯约定顺序为:
background: 背景颜色 背景图片地址 背景平铺 背景图像滚动 背景图片位置;

div {
    background: transparent url(image.jpg) repeat-y fixed top ;
}

这是实际开发中,我们更提倡的写法。

6.CSS背景色半透明

CSS3 为我们提供了背景颜色半透明的效果。

div {
    background: rgba(0, 0, 0, 0.3);
}

最后一个参数是 alpha 透明度,取值范围在 0~1之间
我们习惯把 0.3 的 0 省略掉,写为 background: rgba(0, 0, 0, .3);
注意:背景半透明是指盒子背景半透明,盒子里面的内容不受影响

四、CSS界面样式

1.更改用户的鼠标样式

li {
    cursor: pointer;
}

设置或检索在对象上移动的鼠标指针采用何种系统预定义的光标形状。

属性值 描述
default
箭头(默认)
pointer
小手
move
移动
text
文本
not-allowed
禁止

2.表单轮廓

给表单添加 outline: 0; 或者 outline: none; 样式之后,就可以去掉默认的蓝色边框。

input {
    outline: none; 
}

3.防止表单域拖拽

实际开发中,我们文本域右下角是不可以拖拽的。

textarea{ 
    resize: none;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351