CSS基础:浅聊2D转换

2024-06-18 21:18

本文主要是介绍CSS基础:浅聊2D转换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转换(transform)是CSS3中具有颠覆性的特征之一,可以实现元素的唯一,旋转,缩放等效果。

2D,不是刘备称结义兄弟关羽二弟这个称呼。2D是依托于二维坐标系的。

在这里插入图片描述

而2D转换时改变标签再二维平面上位置和形状的一种技术。

2D转换之移动(translate)

2D移动是2D转换里面的一种功能,可以改变元素再页面中的位置,类似定位。

格式:

transform:translate(x,y);
/*或者分开写*/
transform:translateX(n);
transform:translateY(n);

演示:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>测试文档</title><style>div{width: 200px;height: 200px;}.d1{background-color: #f86262;transform: translate(50%,50%);}.d2{background-color: #4a90e2;}</style>
</head>
<body><div  class="d1"></div>
<div  class="d2"></div></body>
</html>

在这里插入图片描述

可以看出:

  • 位置移动像是相对定位,不但位置移动,同时原来自己位置还是没有让开。
  • translate中的百分比单位是相对于自身元素的百分比
  • 其对行内元素没有效果。

例子演示通过移动让元素位置居中

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>测试文档</title><style>.d1{position:  relative;width: 800px;height: 800px;background-color: #f86262;transform: translate(50%,50%);}.d2{position: absolute;top: 50%;left: 50%;width: 100px;height: 100px;background-color: #4a90e2;transform: translate(-50%,-50%);}</style>
</head>
<body><div  class="d1"><div  class="d2"></div>
</div>
</body>
</html>

在这里插入图片描述

2D转换之旋转(rotate)

2D选择指的是让元素再2维度的屏幕内顺时针选择或者逆时针旋转的操作。

格式:

tranform:rotate(度数);

解释:

  • rotate里面单位是度数(deg),比如:90deg;
  • 角度为正的时候,顺时针,负数几种为逆时针。
  • 默认的时候旋转是旋转点是元素的中心。当然也可以是rotateX,以及rotateY等设置旋转中心。

演示:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>测试文档</title><style>img{position: relative;top: 100px;left: 40%;width: 400px;height: 400px;border-radius: 200px;border: 2px solid #d10000;transition:1s ease;}img:hover{transform: rotate(45deg);}</style>
</head>
<body><img src="jpg/pkq.png"></body>
</html>

在这里插入图片描述

演示2:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>测试文档</title><style>div{position: relative;width: 200px;height: 10px;border :1px solid black;}div:after{position: absolute;top: 1px;right: 4px;width: 5px;height: 5px;content: "";border-right:1px solid black;border-bottom: 1px solid black;transform: rotate(45deg);}</style>
</head>
<body>
<div >
</div>
</body>
</html>

在这里插入图片描述

2D转换中心 transform-origin

这个属性是设置元素转换的中心点。

格式:

transform-origin:x y;

注意:

  • x y 默认转换是中心(50% 50%)

  • 注意后面的参数x和y用空格隔开。其还可以设置象素,或者方向名字(top,bottom等)

演示:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>测试文档</title><style>img{width: 200px;height: 200px;border :1px solid red;border-radius: 100px;transform-origin: bottom center;transition: 1s ease;}img:hover{transform: rotate(90deg);}</style>
</head>
<body><img src="jpg/pkq.png">
</body>
</html>

在这里插入图片描述

例子来一个切换图片的演示。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>测试文档</title><style>div{width: 100px;height: 100px;overflow: hidden;}.father{position: relative;margin: 10px auto;border: 1px solid #000000;}.son1{position: absolute;background-color: #f86262;transform-origin: bottom left;transition: 1s ease;}.son2{background-color: #4a90e2;}.son1:hover{transform: rotate(90deg);}</style>
</head>
<body>
<div class="father"><div class="son1">son1</div><div class="son2">son2</div>
</div>
</body>
</html>

在这里插入图片描述

2D转换之缩放(scale)

这个简单的理解就是元素的放大和缩小,所以需要添加scale这个属性。

格式:

transform:scale(x,y);

注意:

  • 这个xy是通过逗号分隔的,一般为数字代表是原来元素的倍数,如果写一个参数那就是xy值一样。scale(2,2)=scale(2)
  • scale最大的优势是,可以设置转换中心的缩放,默认为中心缩放,不过最重要的是缩放不影响其它的盒子。

演示:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>测试文档</title><style>div{margin: 10px auto;width: 100px;height: 100px;background-color: red;transition: 1s ease;}div:hover{transform: scale(2,3);}</style>
</head>
<body><div  >
</div>
<hr/>
</body>
</html>

在这里插入图片描述

很多网站鼠标移动到图片上,图片变大就可以使用这个属性。所以再用一个例子演示:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>测试文档</title><style>a{text-decoration: none;color: #d10000;}li{float: left;list-style: none;width: 20px;height: 20px;line-height: 10px;line-height: 20px;text-align: center;border: 1px solid #000000;border-radius: 20px;margin: 5px;transition: 1s ease;/*为了证明可以修缩放的点*/transform-origin: top center;}li:hover{transform: scale(2);}</style>
</head>
<body>
<ul><li><a href="#">1</a></li><li><a href="#">2</a></li><li><a href="#">3</a></li><li><a href="#">4</a></li><li><a href="#">5</a></li><li><a href="#">6</a></li>
</ul></body>
</html>

在这里插入图片描述

2D转换复合写法

自然所有的转换的属性值可以同时写在一个transform属性后面,这个需要注意下:

  • 同时使用多个转换一般格式

    transform:translate() rotate() scale()
  • 注意顺序会影响转换的效果,先旋转会修改坐标轴的方向,所以有位移的时候一定要把位移放在最前面。

演示:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>测试文档</title><style>div{width: 100px;height: 100px;}.d1{background-color: #4a90e2;transition: 1s ease;}.d2{background-color: #f86262;transition: 1s ease;}.d1:hover{transform: translate(200px,200px) rotate(360deg) scale(1.1);}.d2:hover{transform: rotate(360deg) scale(1.1) translate(200px,200px) ;}</style>
</head>
<body>
<div class="d1">d1</div>
<hr />
<div class="d2">d2</div></body>
</html>

在这里插入图片描述

这篇关于CSS基础:浅聊2D转换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1073075

相关文章

Python轻松实现Word到Markdown的转换

《Python轻松实现Word到Markdown的转换》在文档管理、内容发布等场景中,将Word转换为Markdown格式是常见需求,本文将介绍如何使用FreeSpire.DocforPython实现... 目录一、工具简介二、核心转换实现1. 基础单文件转换2. 批量转换Word文件三、工具特性分析优点局

Java利用Spire.Doc for Java实现在模板的基础上创建Word文档

《Java利用Spire.DocforJava实现在模板的基础上创建Word文档》在日常开发中,我们经常需要根据特定数据动态生成Word文档,本文将深入探讨如何利用强大的Java库Spire.Do... 目录1. Spire.Doc for Java 库介绍与安装特点与优势Maven 依赖配置2. 通过替换

SpringBoot返回文件让前端下载的几种方式

《SpringBoot返回文件让前端下载的几种方式》文章介绍了开发中文件下载的两种常见解决方案,并详细描述了通过后端进行下载的原理和步骤,包括一次性读取到内存和分块写入响应输出流两种方法,此外,还提供... 目录01 背景02 一次性读取到内存,通过响应输出流输出到前端02 将文件流通过循环写入到响应输出流

SpringBoot+Vue3整合SSE实现实时消息推送功能

《SpringBoot+Vue3整合SSE实现实时消息推送功能》在日常开发中,我们经常需要实现实时消息推送的功能,这篇文章将基于SpringBoot和Vue3来简单实现一个入门级的例子,下面小编就和大... 目录前言先大概介绍下SSE后端实现(SpringBoot)前端实现(vue3)1. 数据类型定义2.

使用C#实现将RTF转换为PDF

《使用C#实现将RTF转换为PDF》RTF(RichTextFormat)是一种通用的文档格式,允许用户在不同的文字处理软件中保存和交换格式化文本,下面我们就来看看如何使用C#实现将RTF转换为PDF... 目录Spire.Doc for .NET 简介安装 Spire.Doc代码示例处理异常总结RTF(R

前端Visual Studio Code安装配置教程之下载、汉化、常用组件及基本操作

《前端VisualStudioCode安装配置教程之下载、汉化、常用组件及基本操作》VisualStudioCode是微软推出的一个强大的代码编辑器,功能强大,操作简单便捷,还有着良好的用户界面,... 目录一、Visual Studio Code下载二、汉化三、常用组件1、Auto Rename Tag2

JavaScript装饰器从基础到实战教程

《JavaScript装饰器从基础到实战教程》装饰器是js中一种声明式语法特性,用于在不修改原始代码的情况下,动态扩展类、方法、属性或参数的行为,本文将从基础概念入手,逐步讲解装饰器的类型、用法、进阶... 目录一、装饰器基础概念1.1 什么是装饰器?1.2 装饰器的语法1.3 装饰器的执行时机二、装饰器的

Java JAR 启动内存参数配置指南(从基础设置到性能优化)

《JavaJAR启动内存参数配置指南(从基础设置到性能优化)》在启动Java可执行JAR文件时,合理配置JVM内存参数是保障应用稳定性和性能的关键,本文将系统讲解如何通过命令行参数、环境变量等方式... 目录一、核心内存参数详解1.1 堆内存配置1.2 元空间配置(MetASPace)1.3 线程栈配置1.

OFD格式文件及如何适应Python将PDF转换为OFD格式文件

《OFD格式文件及如何适应Python将PDF转换为OFD格式文件》OFD是中国自主研发的一种固定版式文档格式,主要用于电子公文、档案管理等领域,:本文主要介绍OFD格式文件及如何适应Python... 目录前言什么是OFD格式文档?使用python easyofd库将PDF转换为OFD第一步:安装 eas

基于Java实现PPT到PDF的高效转换详解

《基于Java实现PPT到PDF的高效转换详解》在日常开发中,经常会遇到将PPT文档批量或单文件转换为PDF的需求,本文将详细介绍其使用流程、核心代码与常见问题解决方案,希望对大家有所帮助... 目录一、环境配置Maven 配置Gradle 配置二、核心实现:3步完成PPT转PDF1. 单文件转换(基础版)