transform的2D部分,嗯…就这个标题了。
上一次写了transition的内容,这次就写拼写很类似的另外一个属性transform好了……我英语差这件事就不要吐槽了,下面是正文,真的:
transition是过渡,transform是变换。
transform分为2D变换和3D变换,简直碉堡了,其实3D变换就是比2D变换多了1D,可以简单这么理解,具体是不是等下次说3D的时候再说,这次只说2D。
在2D转换里我们可以实现斜切(skew),缩放(scale),旋转(rotate)以及位移(translate)元素的效果(还有一个矩阵-matrix,放括号里的原因是因为几乎不用它…反正我几乎不用,因为太难…不过我还是准备为它单写一篇文章,嗯,就这么定了!)。
注意: Internet Explorer 10, Firefox, 和 Opera支持transform 属性。Chrome 和 Safari 要求前缀 -webkit- 版本。 Internet Explorer 9 要求前缀 -ms- 版本。
从简单的translate位移开始说,这个效果需要两个参数(x轴位移量与y轴位移量)比如下面这个例子
css里是这么写的:
.box{
width:200px;
height: 150px;
background-color:#bec3c7;
margin: 20px 0;
}
.box div{
width: 100px;
height: 50px;
}
.contrast{
background-color: #3598db;
}
.translate{
background-color:#f1c40f;
transform: translate(50px, 30px);
-ms-transform: translate(50px, 30px); /* IE 9 */
-webkit-transform: translate(50px, 30px); /* Safari and Chrome */
}
html里是这么写的:
<div class="box">
<div class="contrast">这个是用来做对比的</div>
</div>
<div class="box">
<div class="contrast translate">这个是translate</div>
</div>
然后来说说这个rotate旋转,这个效果只需要一个参数,就是旋转多少度,来继续吃栗子:
css里是这么写的:
.box{
width:200px;
height: 150px;
background-color:#bec3c7;
margin: 20px 0;
}
.box div{
width: 100px;
height: 50px;
}
.contrast{
background-color: #3598db;
}
.rotate{
background-color:#e67f22;
transform:rotate(45deg);
-ms-transform:rotate(45deg); /* IE 9 */
-webkit-transform:rotate(45deg); /* Safari and Chrome */
}
html里是这么写的:
<div class="box">
<div class="contrast">这个是用来做对比的</div>
</div>
<div class="box">
<div class="contrast translate">这个是translate</div>
</div>
<div class="box">
<div class="contrast rotate">这个是rotate</div>
</div>
再然后是scale缩放,这个效果又要两个参数了,分别是横向缩放比例和纵向缩放比例,栗子在这:
css里是这么写的:
.box{
width:200px;
height: 150px;
background-color:#bec3c7;
margin: 20px 0;
}
.box div{
width: 100px;
height: 50px;
}
.contrast{
background-color: #3598db;
}
.scale{
background-color:#e84c3d;
transform: scale(0.5,2);
-ms-transform: scale(0.5,2); /* IE 9 */
-webkit-transform: scale(0.5,2); /* Safari and Chrome */
}
html里是这么写的:
<div class="box">
<div class="contrast">这个是用来做对比的</div>
</div>
<div class="box">
<div class="contrast translate">这个是translate</div>
</div>
<div class="box">
<div class="contrast rotate">这个是rotate</div>
</div>
<div class="box">
<div class="contrast scale">这个是scale</div>
</div>
这次的最后说一下这个skew斜切,也有叫斜拉、拉伸,不过我还是比较习惯ps中文版的叫法“斜切”,先不放栗子,先说这个效果的意思。
这个效果需要两个参数,分别对应横向斜切角度和纵向斜切角度,我这里先给元素一个参数,另外一个先不动,看下效果:
css里是这样的:
.box{
width:200px;
height: 150px;
background-color:#bec3c7;
margin: 20px 0;
}
.box div{
width: 100px;
height: 50px;
}
.contrast{
background-color: #3598db;
}
.skew-x{
background-color:#9a59b5;
transform:skew(30deg,0);
-ms-transform:skew(30deg,0); /* IE 9 */
-webkit-transform:skew(30deg,20deg); /* Safari and Chrome */
}
html里是这样的:
<div class="box">
<div class="contrast">这个是用来做对比的</div>
</div>
<div class="box">
<div class="contrast skew-x">这个是skew</div>
</div>
出来效果是这样的:
变成了一个平行四边形(其实长方形也是平行四边形啊~),参数中给的是30度,出来的效果是竖着的两条边与横着的边的垂线(y轴)产生了一个夹角,度数是30度,给的参数值也是30度,产生的变化说成普通话就是y轴逆时针旋转了30度(参考系的y轴依然是不会变的,这个时候给"translate:0 10px;"依然是向下的,而不是向右下);
如果这个时候把第二个参数也写上,就变成这样了:
css里是这样的:
.box{
width:200px;
height: 150px;
background-color:#bec3c7;
margin: 20px 0;
}
.box div{
width: 100px;
height: 50px;
}
.contrast{
background-color: #3598db;
}
.skew{
background-color:#9a59b5;
transform:skew(30deg,20deg);
-ms-transform:skew(30deg,20deg); /* IE 9 */
-webkit-transform:skew(30deg,20deg); /* Safari and Chrome */
}
html里是这样的:
<div class="box">
<div class="contrast">这个是用来做对比的</div>
</div>
<div class="box">
<div class="contrast skew">这个是skew</div>
</div>
可以看到,这次的横着的两条边与x轴成夹角的度数是20度了,不过这次的旋转方向是顺时针的了…
通过上面的栗子可以看出,transform的效果是会让内部一起出现对应的变化,而不仅仅只是改变边框,并且子元素及时大到超过父元素的范围,依然不会影响到layout。
今天就到这,我去准备matrix矩阵的内容了…
transform的2D部分,嗯…就这个标题了。的更多相关文章
- 关于transform的2D
在transform的学习中,自己总结了一点经验. 我们知道transform有2D和3D的两大类变换,这里分享下关于2D的属性简单示例: 一.2D变换: (x为水平,y为垂直) 1.skew(斜拉 ...
- transform做2d和3d变形(css动画一)
前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! 有段时间我是没理清transform.translate.transition和animation之间的关 ...
- CSS3 Transform变形(2D转换)
Transform:对元素进行变形:Transition:对元素某个属性或多个属性的变化,进行控制(时间等),类似flash的补间动画.但只有两个关键贞.开始,结束.Animation:对元素某个属性 ...
- css3的transform ,2D变换
transformtransform的中文翻译就是变换,改变,改观,转换的意思 在css中的主要作用就是对一个div或元素进行样式的改变. 他的属性(变换方式)有:平移,旋转,缩放,扭曲transla ...
- CSS3 transform 属性(2D,3D旋转)
一.语法 div{ transform:rotate(7deg); -ms-transform:rotate(7deg); /* IE 9 */ -moz-transform:rotate(7deg) ...
- transform的2D和3D变换
transform取值 none:默认值,即是无转换 matrix(,,,,,): 以一个含六值的(a,b,c,d,e,f)变换矩阵的形式指定一个2D变换,相当于直接应用一个[a,b,c,d,e,f] ...
- transform CSS3 2D知识点汇总
transform转换属性的5个值: 1. translate(x值,y值) 移动效果. 2.rotate(45deg) 旋转效果. 3.scale(x轴倍数,y轴倍数) 缩放效果. 4.ske ...
- CSS 3学习——transform 2D转换
首先声明一点,transform属性不为none的元素是它的定位子元素(绝对定位和固定定位)的包含块,而且对内创建一个新的层叠上下文. 注意:可以通过 transform-box 属性指定元素的那个盒 ...
- z-index和transform
z-index和transform是CSS中的属性,但很少同学将二者联系到一起,感觉他们八杆子打不上.事实真的是这样吗?如果你也不能确认,这篇文章就值得你花点时间阅读.因为阅读完了,你会有所收获的. ...
随机推荐
- 大到可以小说的Y组合子(零)
问:啊!我想要一个匿名的递归… 答:Y(音同Why)… … … 问:作为一位命令式语言的使用者,为什么会突然折腾起Y组合子呢? 答:的确,这事儿要从很久以前的几次搁浅开始说起…上学的时候,从来没有接触 ...
- [跟我学spring学习笔记][IoC]
IoC基础 什么是IoC Ioc—Inversion of Control,即“控制反转”,不是什么技术,而是一种设计思想. ioc做什么 IoC容器帮对象找相应的依赖对象并注入,而不是由对象主动去找 ...
- Gstreamer的一些基本概念与A/V同步分析
一.媒体流(streams )流线程中包含事件和缓存如下:-events -NEW_SEGMENT (NS) -EOS (EOS) * - ...
- C# 执行存储过程
SqlParameter[] paras = BuildParas(id, time, name); bool bRet = ExcuteProcedure(“数据库连接字符串”, "存储过 ...
- vim常用指令一览
插入指令 i 在光标处插入字符 I 在光标所在行最前插入 a 在光标所在字符后面插入 A 在光标所在行的最后插入 o 在光表所在行下面插入一行 O 在光标所在行上面插入一行 r 替换光标所在字符,只替 ...
- hibernate中.hbm.xml和注解方式自动生成数据表的简单实例(由新手小白编写,仅适用新手小白)
绝逼新手小白,so 请大神指点! 如果真的错的太多,错的太离谱,错的误导了其他小伙伴,还望大神请勿喷,大神请担待,大神请高抬贵嘴......谢谢. 好了,正题 刚接触ssh,今天在搞使用.hbm.xm ...
- linux cat命令的<<EOF
初初开始学习linux的命令,只对linux一些简单命令有一些了解! 首先我看到网上有一些创建一个文件采用的命令是(mkdir创建文件夹):cat > test1.txt <<EOF ...
- Eloquent ORM 学习笔记
最近在学习Laravel,觉得ORM功能很强大,我这里只是简单探索了一点,如果有更好的笔记,还请分享. 因为重点在于Eloquent ORM,所以路由设置,控制器就不详细描述了,这里直接进入Model ...
- python运维开发(十七)----jQuery续(示例)web框架django
内容目录: jQuery示例 前端插件 web框架 Django框架 jQuery示例 dom事件绑定,dom绑定在form表单提交按钮地方都会绑定一个onclick事件,所有查看网站的人都能看到代码 ...
- MVC 中使用uploadify上传图片遇到的蛋疼问题
MVC 中使用uploadify上传图片遇到的蛋疼问题 初次使用uploadify上传图片,遇到了一些比较纠结的问题,在这里和大家分享下,有不对的地方还望大神多多指教,希望对刚接触的朋友有所帮助,文采 ...