css图片垂直水平居中及放大(实现水平垂直居中的效果有哪些方法?)
实现水平垂直居中方法有很多种:
一.万能法:
1.已知高度宽度元素的水平垂直居中,利用绝对定位和负边距实现。
<style type="text/css">
.wrapper{
position:relative;
background: #acc;
width: 500px;
height: 500px;
} .content{
background: #aaa;
width:400px;
height:400px;
position: absolute; /*//父元素需要相对定位 */
top: 50%;
left: 50%;
margin-top:-200px ; /* //本身二分之一的height,width */
margin-left: -200px;
} </style> <div class="wrapper">
<div class="content"></div>
</div>
2.已知高度宽度元素的水平垂直居中,利用绝对定位和margin。
.container{
width: 600px;
height: 600px;
position: relative;
}
.center{
width: 300px;
height: 300px;
position: absolute;
top:;
left:;
right:;
bottom:;
margin: auto;
}
二、行内元素(内联元素)水平居中方案:
1.行内元素的水平居中
text-align: center;
width: 200px;
display: inline-block;
2.行内元素-Flex布局:水平垂直居中
设置display:flex; justify-content:center;align-items: center (灵活运用,支持Chroime,Firefox,IE9+)
.box {
display: flex;
justify-content: center; /* 水平居中 */
align-items: center; /* 垂直居中 */
width: 1000px;
height: 600px;
border: 1px solid red;
}
.inner {
width: 300px;
height: 200px;
background-color: red;
} <div class="box">
<section class="inner"></section>
</div>
最简单的写法:
.container{
display: flex;
height: 600px;
}
.center{
margin : auto;
}
行内元素垂直居中设置:
1.父元素高度确定的单行文本(内联元素):设置 height = line-height;
height: 50px;
text-align: center; /*
line-height: 50px;
2.父元素高度确定的多行文本(内联元素):
a:插入 table (插入方法和水平居中一样),然后设置 vertical-align:middle;
b:先设置 display:table-cell 再设置 vertical-align:middle;
.span_box {
display: table;
}
.words_span {
display: table-cell;
vertical-align: middle;
} <div class="span_box bg_box">
<span class="words_span">
父元素使用display:table和子元素使用display:table-cell属性来模拟表格,子元素设置vertical-align:middle即可垂直居中
</span>
</div>
三、块级元素居中方案
1.定宽块级元素水平居中
设置 左右 margin 值为 auto;
margin: 0 auto;
2.不定宽块状元素
水平居中
a:在元素外加入 table 标签(完整的,包括 table、tbody、tr、td),该元素写在 td 内,然后设置 margin 的值为 auto;
b:给该元素设置 displa:inine 方法;
c:父元素设置 position:relative 和 left:50%,子元素设置 position:relative 和 left:50%;
垂直居中设置:
使用position:absolute(fixed),设置left、top、margin-left、margin-top的属性;
利用position:fixed(absolute)属性,margin:auto这个必须不要忘记了;
利用display:table-cell属性使内容垂直居中;
使用css3的新属性transform:translate(x,y)属性;
使用:before元素;
四、css3的transform属性
.container{
width: 100%;
height: 600px;
position: relative;
}
.center{
position:absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
下面是本人做项目时遇到的一个需求:要求:图片垂直水平居中及放大 的例子
<div class="imginfan"> <a class="tooltip" href="#">
<img :src="item.images" height="63" width="62" alt=""> <!-- 放大图 -->
<div class="inner">
<img class="" :src="item.images" height="360" width="280" alt="">
</div>
</a>
</div>
/* 图片居中*/
.imginfan{ position: relative; }
.imginfan img {
text-align:center;
position: absolute;
top:50%;
left:50%;
transform: translate(-50%,-50%);
transition: all 0.6s; }
.imginfan img :hover{transform: scale(1.2); }
/* 图片放大部分 相对于原先盒子定位 */
.tooltip{ z-index:2; }
.tooltip:hover{ z-index:3; }
.tooltip .inner{ display: none; }
.tooltip:hover .inner{ /*div的inner标签仅在 :hover 状态时显示*/
display:block;
position:absolute;
top:100px;
left:250px;
border:1px solid black;
background-color:#F2F2F2;
z-index:999; }
css图片垂直水平居中及放大(实现水平垂直居中的效果有哪些方法?)的更多相关文章
- 关于用css实现文本和图片垂直水平居中
关于用css实现文本和图片垂直水平居中 一直相信好记性不如烂笔头,最近遇到很多用到垂直居中的,整理一下以便日后查阅. 一.文本垂直水平居中 1.水平居中: 文字水平居中没什么好说的,用text-a ...
- css实现垂直水平居中的方法(个数不限)?
方法一:使用绝对定位 大家都知道margin:0 auto;能够实现水平居中,但却不知道margin:0 auto;也是可以实现垂直居中的: 给居中元素添加如下样式: .Absolute-Center ...
- css图片居中(水平居中和垂直居中)
css图片居中(水平居中和垂直居中) css图片居中分css图片水平居中和垂直居中两种情况,有时候还需要图片同时水平垂直居中,下面分几种居中情况分别介绍. css图片水平居中 利用margin: 0 ...
- CSS之垂直水平居中的背后
最开始,我想说,这个体系有点大,我写的并不好.就当作是一个思路吧,虽然这个思路有点乱.几乎每一个实现方案的背后都是该属性及其组合的原理,每一个都要剖析其规范细节的话,这篇文章绝不会是这样的篇幅,所以每 ...
- CSS实现图片在div a标签中水平垂直居中
CSS实现图片在div a标签中水平垂直居中 <div class="demo"> <a href="#"> <img src=& ...
- css实现垂直水平居中的5种方法
css实现垂直水平居中的5种方法 给父元素设置table-cell,text-align,vertical-align #big{ width: 200px; height: 200px; borde ...
- CSS 水平垂直居中的几种实现方法
前言 项目中经常碰到需要实现水平垂直居中的样式.下面就总结几种常用的方法 水平对齐+行高 [思路一]text-align + line-height实现单行文本水平垂直居中 <style> ...
- 【css】图片垂直水平居中
一.已知宽高的图片实现垂直水平居中 1.借助margin-top负边距实现垂直居中 <!DOCTYPE html> <html> <head> <meta c ...
- css文本垂直水平居中
一.单行文本居中 .content{ height:100px; line-height:100px; text-align:center; border:1px solid red; } 效果图 二 ...
随机推荐
- Dependency injection in .NET Core的最佳实践
我们知道依赖注入(DI)是一种实现对象及其协作者或依赖关系之间松散耦合的技术. ASP.NET Core包含一个简单的内建容器来支持构造器注入. 我们试图将DI的最佳实践带到.NET Core应用程序 ...
- Spring Cloud Gateway中异常处理
最近我们的项目在考虑使用Gateway,考虑使用Spring Cloud Gateway,发现网关的异常处理和spring boot 单体应用异常处理还是有很大区别的.让我们来回顾一下异常. 关于异常 ...
- spring学习(二) ———— AOP之AspectJ框架的使用
前面讲解了spring的特性之一,IOC(控制反转),因为有了IOC,所以我们都不需要自己new对象了,想要什么,spring就给什么.而今天要学习spring的第二个重点,AOP.一篇讲解不完,所以 ...
- [总结] 动态DP学习笔记
学习了一下动态DP 问题的来源: 给定一棵 \(n\) 个节点的树,点有点权,有 \(m\) 次修改单点点权的操作,回答每次操作之后的最大带权独立集大小. 首先一个显然的 \(O(nm)\) 的做法就 ...
- [android] 采用post的方式提交数据
GET:内部实现是组拼Url的方式,http协议规定最大长度4kb,ie浏览器限制1kb POST和GET的区别比较了一下,多了几条信息 Content-Type:application/x-www- ...
- 深入理解JAVA中的NIO
前言: 传统的 IO 流还是有很多缺陷的,尤其它的阻塞性加上磁盘读写本来就慢,会导致 CPU 使用效率大大降低. 所以,jdk 1.4 发布了 NIO 包,NIO 的文件读写设计颠覆了传统 IO 的设 ...
- 面试HashMap之追命5连问
1.HashMap底层实现数据结构? 总的来说,HashMap就是数组+链表的组合实现,每个数组元素存储一个链表的头结点,本质上来说是哈希表“拉链法”的实现. HashMap的链表元素对应的是一个静态 ...
- webpack4 系列教程(十四):Clean Plugin and Watch Mode
作者按:因为教程所示图片使用的是 github 仓库图片,网速过慢的朋友请移步<webpack4 系列教程(十四):Clean Plugin and Watch Mode>原文地址.更欢迎 ...
- 封装个 Android 的高斯模糊组件
本篇文章已授权微信公众号 hongyangAndroid (鸿洋)独家发布 最近基于 Android StackBlur 开源库,根据自己碰到的需求场景,封装了个高斯模糊组件,顺便记录一下. 为什么要 ...
- C# 任务 数据加载不影响其他操作
private void button1_Click(object sender, EventArgs e) { //this.timer1.Enabled = true; Task t1 = new ...