CSS中图片旋转超出父元素解决办法
发布时间:2023-09-06 16:32:44 作者: 小月亮
我要评论
本文主要介绍了CSS中图片旋转超出父元素解决办法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
下面的两种解决办法都会导致图片缩小,可以给图片进行初始化的宽高设置
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
html,body {
margin: 0;
padding: 0;
}
#box {
box-sizing: border-box;
width: 100%;
height: 240px;
background: pink;
}
#image {
transform: rotate(0);
object-fit: contain;
}
#btn {
margin-top: 100px;
}
</style>
</head>
<body>
<div id="box">
<img id="image" src="https://www.runoob.com/images/pulpit.jpg" alt="">
<!-- <img id="image" src="https://pics0.baidu.com/feed/c2cec3fdfc039245259830d9727ca5c77c1e2521.jpeg@f_auto?token=b910f4287521294b9469788c77a3ac93&s=A12326BEC5137FDECCBC8DC1030060BB" alt=""> -->
</div>
<button id="btn">旋转</button>
</body>
<script>
window.onload = () => {
let btn = document.getElementById('btn')
let image = document.getElementById('image')
let box = document.getElementById('box')
let childRawWidth = image.offsetWidth // 原始的图片宽
let childRawHeight = image.offsetHeight // 原始的图片高
let deg = 0
btn.onclick = function() {
if (deg > 360) {
deg = 0
} else {
deg += 90
}
// 方法一:使用 scale -- 父元素的高度不固定
// let childWidth = image.offsetWidth
// let childHeight = image.offsetHeight
// let scalePix = 1
// if (childWidth > childHeight) {
// scalePix = childHeight / childWidth
// } else {
// scalePix = childWidth / childHeight
// }
// image.style.transform = `rotate(${deg}deg) scale(${scalePix}, 1)`
// 方法二:将图片重新设置宽高 -- 父元素的高度固定
let parentWidth = box.offsetWidth
let parentHeight = box.offsetHeight
if (childRawWidth > childRawHeight) {
image.style.width = childRawHeight + 'px'
}
image.style.transform = `rotate(${deg}deg)`
}
}
</script>
</html>原始图片:

超出的效果图:

解决之后的效果图:

到此这篇关于CSS中图片旋转超出父元素解决办法的文章就介绍到这了,更多相关CSS 图片旋转超出父元素内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!
相关文章
本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋友跟随小编一起看看吧2025-06-20- 本文给大家讲解CSS 的三种核心布局机制——普通流(Normal Flow)、浮动(Float)和定位(Positioning)对于创建灵活、响应式的网页至关重要,本文将深入探讨这三种机制的工作原2025-06-19
文章介绍如何用CSS实现角标效果,通过.active类结合::after和::before伪元素,利用定位、边框和旋转创建红色边框与白色三角形的提示标志,适用于按钮或卡片元素的视觉增强设计2025-06-19CSS Anchor Positioning重新定义锚点定位的时代来临(最新推荐)
CSS Anchor Positioning是一项仍在草案中的新特性,由 Chrome 125 开始提供原生支持需启用实验 flag,它允许你在 CSS 中通过锚点(anchor)来相对于任意 DOM 元素定位,本文2025-06-17CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比
CSS 中的 position 属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布局和层叠关系,以下是 static、relative、absolute、fixed、sticky 的详细对比和应用2025-06-17CSS place-items: center解析与用法详解
place-items: center; 是一个强大的 CSS 简写属性,用于同时控制 网格(Grid) 和 弹性盒(Flexbox) 布局中的对齐方式,本文给大家介绍CSS place-items: center; 详解与用法2025-06-17
在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧2025-06-17- CSS单位区别与使用场景总结:px绝对、vw/vh响应式,%继承父尺寸,em/rem文字缩放,vmin/vmax适应宽高变化,固定布局用px或%,响应式布局用vw/vh/rem,文字用em或rem,本文给大家2025-06-16
- 这篇文章主要介绍了CSS 样式表的四种应用方式及css注释的应用小结,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧2025-05-21
- 在CSS布局中,padding属性是控制元素内容与其边框之间距离的关键工具,本文介绍CSS基础中padding,通过本文的介绍,我们深入了解了padding的基本概念、简写方法以及它对元2025-05-16





最新评论