CSS中的一些细节
一、塌陷
1.当position设置为:absolute或者fixed时,元素的display会转换为block。(设置float也会产生这样的效应)
2.正常情况下,div会被内容撑开,但是如果设置了1.的情况下,父元素就会产生塌陷,失去高度。
解决办法:
给父元素设置高度。
给父元素设置overflow: hidden;
二、文本的自动换行
对于那种长单词,会超出元素的实际宽度。
解决办法
word-break:break-all;
三、文本溢出部分隐藏
解决办法
overflow: hidden;
四、溢出打点
4.1 单行文本打点
p{
width: 200px;
overflow: hidden;
white-space: nowrap; /*不换行*/
text-overflow: ellipsis; /*溢出部分点样式*/
}
4.2 多行文本溢出打点
p{
width: 200px;
overflow: hidden;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-line-clamp: 3; /*行数*/
-webkit-box-orient: vertical;
}
五、flex布局
当设置了display: flex;后,那么子元素的float、clear和vertical-align属性失效。
flex布局,分为容器和项目两个部分。一般而言,容器就是父元素,项目就是该父元素下的子元素。
(1)flex-direction: row(默认)| row-reverse | column | column-reverse
决定主轴方向,也就是定义容器元素是行方向排列还是列方向排列,
并且定义它的起点方向,例如行方向是从左向右还是从右向左。
反之,列方向是从上到下还是相反呢。(row是行,column是列。)
(2)flex-wrap: nowrap(默认) | wrap | wrap-reverse
决定是否都拍在一行(列)里,也就是是否换行。
以行为例有三种情况,不换行、换行(第一行在上方),换行(第一行在下方)
(3)flex-flow: row nowrap(默认)
这是flex-direction属性和flex-wrap属性的简写形式,
第一个参数定义排列方式,第二个参数定义是否换行。
(4)justify-content: flex-start | flex-end | center | space-between | space-around
调整主轴方向上项目的对齐方式。
以行向排列为例,可以设置为靠左对齐,靠右对齐,水平居中对齐。
还有两个特殊的:
space-between(两端对齐,相当于文本对齐【text-align】里的justify);
space-around(元素两侧间隔相等,且比它与边框的间隔大一倍)
(5)align-items: flex-start | flex-end | center | initial(从父元素继承)
调整交叉轴方向上的项目对齐方式。
如果行方向是主轴方向,那么列方向就是交叉轴方向。
以行方向为例,可以设置垂直在上,垂直在下,垂直居中。
两个特殊的:
baseline(项目元素第一行文字的基线对齐);
stretch是默认的(如果项目元素没有设置高度,那么它就会自动拉伸高度至整个容器高度)
六、rem适配方案
使用 rem 单位来定义文字的大小最大的问题在于这些值有点难以使用。让我们来看一个例子,假设根元素的文字大小是 16px,我们常用的文字大小转换为 rem 值如下:
10px = 0.625rem
12px = 0.75rem
14px = 0.875rem
16px = 1rem (base)
18px = 1.125rem
20px = 1.25rem
24px = 1.5rem
30px = 1.875rem
32px = 2rem
动态修改font-size:
媒体查询方式
@media screen and (max-width: 360px) and (min-width: 321) {
html : {font-size: 24px}
}
@media screen and (max-width: 320px) {
html : {font-size: 20px}
}
js代码控制
let htmlWidth = document.documentElement.clientWidth || document.body.clientWidth;
let htmlDom=document.getElementByTagName('html')[0];
htmlDom.style.fontSize = htmlWidth/10 +'px';
sass计算
@function px2rem($px) {
$rem: 37.5px;//基准值,iPhone为参考375/10
@return ($px / $rem) _rem;
}
width: px2rem(50px);
七、元素居中
文本(img也是)元素水平居中 text-align: center;
块级元素水平居中 margin: 0 auto;
单行文本垂直居中 设置line-height和div的height
不确定高度的文本垂直居中 使用padding-top和padding-bottom
确定高度的块级元素垂直居中 position: absolute; top:50%; margin-top: -高度的一半;
绝对定位实现垂直居中 position: absolute; top: 0; right: 0; bottom: 0; left: 0; margin: auto;
给父元素设置 display: table-cell; vertical-align: middle;
css3 设置完定位和top,left后设置 transform: translate(-50%,-50%);
弹性盒子(有兼容问题)
CSS中的一些细节的更多相关文章
- 原来css中的border还可以这样玩
原来css中的border还可以这样玩 前面的话: 在看这篇文章之前你可能会觉得border只是简单的绘制边框,看了这篇文章,我相信你也会跟我一样说一句"我靠,原来css中的border还可 ...
- CSS特异性(CSS Specificity)的细节之CSS样式权重的计算与理解(CSS样式覆盖规则)
本篇讲解CSS特异性(CSS Specificity)的细节,也就是CSS样式选择器的权重计算 通过计算选择器的权重(weight)最终决定哪个选择器将获得优先权去覆盖其他选择器的样式设定,即“优先原 ...
- css中的border还可以这样玩
在看这篇文章之前你可能会觉得border只是简单的绘制边框,看了这篇文章,我相信你也会跟我一样说一句"我靠,原来css中的border还可以这样玩".这篇文章主要是很早以前看了别人 ...
- CSS遮罩——如何在CSS中使用遮罩
Css遮罩是2008年4月由苹果公司添加到webkit引擎中的.遮罩提供一种基于像素级别的,可以控制元素透明度的能力,类似于png24位或png32位中的alpha透明通道的效果. 图像是由rgb三个 ...
- CSS中Position属性
也许你看到这个标题觉得很简单,确实这是一篇关于CSS中Position属性基础知识的文章,但是关于Position的一些细节也许你不了解. 1.简介 position有五个属性: static | r ...
- 你所不知道的 CSS 滤镜技巧与细节
承接上一篇你所不知道的 CSS 动画技巧与细节,本文主要介绍 CSS 滤镜的不常用用法,希望能给读者带来一些干货! OK,下面直接进入正文.本文所描述的滤镜,指的是 CSS3 出来后的滤镜,不是 IE ...
- 关于CSS中的float可能出现的小问题
关于CSS中的float可能出现的小问题 前言:最近学习CSS的float所遇到点小问题,然后顺便分享给大家. 一.什么是CSS以及float (一) CSS概述 CSS是层叠样式表(英文全称:Cas ...
- 你所不知道的 CSS 阴影技巧与细节 滚动视差?CSS 不在话下 神奇的选择器 :focus-within 当角色转换为面试官之后 NPOI 教程 - 3.2 打印相关设置 前端XSS相关整理 委托入门案例
你所不知道的 CSS 阴影技巧与细节 关于 CSS 阴影,之前已经有写过一篇,box-shadow 与 filter:drop-shadow 详解及奇技淫巧,介绍了一些关于 box-shadow ...
- [转]CSS遮罩——如何在CSS中使用遮罩
特别声明:此篇文章由D姐根据Christian Schaefer的英文文章原名<CSS Masks – How To Use Masking In CSS Now>进行翻译,整个译文带有我 ...
随机推荐
- Netty源码学习系列之1-netty的串行无锁化
前言 最近趁着跟老东家提离职之后.到新公司报道之前的这段空闲时期,着力研究了一番netty框架,对其有了一些浅薄的认识,后续的几篇文章会以netty为主,将近期所学记录一二,也争取能帮未对netty有 ...
- Promise相关学习
what? Promise对象表示一个异步操作的最终状态(完成或失败),以及其返回的值 https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/ ...
- win32 socket http 操作
纯wininet 操作http关键代码如下: HINTERNET hNet = ::InternetOpen(_T("Test"), INTERNET_OPEN_TYPE_DIRE ...
- Nice Jquery Validator 内置属性
required - 必填 适用于 input.textarea.select 输入框.(checkbox 与 radio 请使用 checked 规则)字段必填,则值不能为空.字段非必填,则值为空的 ...
- 关于宝塔面板ftp+sublime
如果sublime通过ftp上传文件传不上去,我的问题在于应该把sftp-config.json中"remote_path": "/",设置成这样.一下午.哎呀 ...
- <Win10开发>UWP使用.Net Native编译时遇到的一些问题。
最近开始尝试把WP8.1 Runtime的项目升级成Win10 UWP,我用的方法没什么技巧性,就是直接复制文件和代码到新建的UWP项目.结果是后台代码未经修改,全部正常运行.但是UI控件的布局有些偏 ...
- sed中使用shell变量
假设希望在 file_to_modified 文件最后新增一行以下信息:传入 shell 脚本文件的第一个参数,以及当前时间(YYYY-MM-DD HH:MMS) date "+%Y-%m- ...
- Android学习笔记:实现层级导航
层级导航示例 层级导航案例 1.收下准备两个Activity的布局文件 activity_main.xml <?xml version="1.0" encoding=&quo ...
- WPF入门(2)——依赖属性
今天我们说说依赖属性 什么是依赖属性? 当然,学术定义依旧Please Baidu:https://baike.baidu.com/item/%E4%BE%9D%E8%B5%96%E5%B1%9E%E ...
- 多语言工作者の十日冲刺<6/10>
这个作业属于哪个课程 软件工程 (福州大学至诚学院 - 计算机工程系) 这个作业要求在哪里 团队作业第五次--Alpha冲刺 这个作业的目标 团队进行Alpha冲刺--第六天(05.05) 作业正文 ...