CSS三角
div {
width: 0;
height: 0;
border: 50px solid transparent;
border-color: red green blue black;
line-height:0;
font-size: 0;
}
1.我们用css边框可以模拟三角效果
2.宽度高度为0
3.我们4个边框都要写,只保留需要的边框颜色,其余的不能省略,都改为transparent透明就好
4.为了照顾兼容性低版本的浏览器,加上font-size;line-height:0
CSS三角强化案例
<head>
<style>
.box1 {
width: 0;
height: 0;
/* 1.只保留右边的边框有颜色 */
border-color: transparent red transparent transparent;
/* 2. 样式都是solid */
border-style: solid;
/* 3. 上边框宽度要大, 右边框 宽度稍小, 其余的边框该为 0 */
border-width: 100px 50px 0 0 ;
}
</style>
</head>
<body>
<div class="box1"></div>
</body>
CSS用户界面样式
鼠标样式cursor
li{
cursor:pointer;
}
属性值 | 描述 |
default | 小白 默认 |
pointer | 小手 |
move | 移动 |
text | 文本 |
not-allowed | 禁止 |
轮廓线outline
给表单添加outline:0; 或者outline:none;样式之后,就可以去掉默认的蓝色边框
input{
outline:none;
}
防止拖拽文本域resize
实际开发中,我们文本域右下角不可以拖拽的
textarea {
resize:none
}
vertical-align属性应用
CSS vertical-align属性使用场景:经常用于设置图片或者表单(行内块元素)和文字垂直对齐.
官方解释:用于设置一个元素的垂直对齐方式,但是他只针对于行内元素或者行内块元素有效.
用法:
vertical-align:baseline/top/middle/bottom
值 | 描述 |
baseline | 默认.元素放置在父元素的基准线上 |
top | 把元素的顶端与行中嘴鸥高元素的顶端对齐 |
middle | 把此元素放置在父元素的中部 |
bottom | 把元素的顶端与行最低的元素顶端对齐 |
解决图片底部默认空白缝隙问题
bug:图片底侧会有一个空白缝隙,原因是行内块元素会和文字的基准线对齐
主要解决方法有两种:
1.给图片添加vertical-align:middle/top/bottom等 (提倡使用的)
2.把图片转换为块级元素 display:block
溢出的文字省略号显示
单行文本溢出显示省略号
当行文本溢出显示省略号必需满足三个条件
/*1. 先强制一行内显示文本*/
white-space:nowrap (normal)
/*2. 超出的部分隐藏*/
overflow:hidden;
/*3. 文字用省略号替代超出的部分*/
text-overflow:ellipsis;
多行文本溢出显示省略号
多行文本溢出显示省略号,有较大的兼容性问题,适合于webkit浏览器或者移动端(移动端大部分都是webkit内核)
/*1. 超出的部分隐藏 */
overflow:hidden;
/*2. 文字用省略号替代超出的部分 */
text-overlow:ellipsis
/* 3. 弹性伸缩盒子模型显示 */
display:-webkit-box;
/* 4. 限制在一个块元素显示的文本的行数 */
-webkit-line-clamp:2;
/* 5. 设置或检索伸缩盒对象的子元素的排列方式 */
-webkit-box-orient:vertical;
常见布局技巧
margin负值运用
1.让每个盒子margin往左侧移动-1px正好压住相邻盒子边框
2.鼠标经过某个盒子的时候,提高当前盒子的层级即可(如果没有定位,则家相对定位(保留位置),如果有定位,择交z-index)
文字围绕浮动元素
行内块巧妙运用
页码在页面中间显示:
-
把这些链接盒子转换为行内块, 之后给父级指定 text-align:center;
-
利用行内块元素中间有缝隙,并且给父级添加 text-align:center; 行内块元素会水平会居
CSS 初始化
不同浏览器对有些标签的默认值是不同的,为了消除不同浏览器对HTML文本呈现的差异,照顾浏览器的兼容,我们需要对CSS 初始化
简单理解: CSS初始化是指重设浏览器的样式。 (也称为CSS reset)
每个网页都必须首先进行 CSS初始化。
这里我们以 京东CSS初始化代码为例。
Unicode编码字体:
把中文字体的名称用相应的Unicode编码来代替,这样就可以有效的避免浏览器解释CSS代码时候出现乱码的问题。
比如:
黑体 \9ED1\4F53 宋体 \5B8B\4F53 微软雅黑 \5FAE\8F6F\96C5\9ED1