`

CSS3感悟1

阅读更多
CSS3 是最新的 CSS 标准。

div#div2
{
transform:rotate(30deg);// 30度
-ms-transform:rotate(30deg); /* IE 9 */
-moz-transform:rotate(30deg); /* Firefox */
-webkit-transform:rotate(30deg); /* Safari and Chrome */
-o-transform:rotate(30deg); /* Opera */
}

CSS3 被划分为模块。
其中最重要的 CSS3 模块包括:
选择器
框模型
背景和边框
文本效果
2D/3D 转换
动画
多列布局
用户界面

通过 CSS3,您能够创建圆角边框,向矩形添加阴影,使用图片来绘制边框 - 并且不需使用设计软件。

div
{
text-align:center;
border:2px solid #a1a1a1;
padding:10px 40px;
background:#dddddd;
width:350px;
border-radius:15px;
-moz-border-radius:25px; /* 老的 Firefox */
}

在 CSS3 中,box-shadow 用于向方框添加阴影:

div
{
width:300px;
height:100px;
background-color:#ff9900;
-moz-box-shadow: 10px 10px 5px #888888; /* 老的 Firefox */
box-shadow: 10px 10px 5px #888888;
}

值 描述 测试
h-shadow 必需。水平阴影的位置。允许负值。
v-shadow 必需。垂直阴影的位置。允许负值。
blur 可选。模糊距离。
spread 可选。阴影的尺寸。
color 可选。阴影的颜色。请参阅 CSS 颜色值。
inset 可选。将外部阴影 (outset) 改为内部阴影。

通过 CSS3 的 border-image 属性,您可以使用图片来创建边框:
div
{
border-image:url(border.png) 30 30 round;
-moz-border-image:url(border.png) 30 30 round; /* 老的 Firefox */
-webkit-border-image:url(border.png) 30 30 round; /* Safari 和 Chrome */
-o-border-image:url(border.png) 30 30 round; /* Opera */
}

CSS3 背景
background-size:属性规定背景图片的尺寸。

在 CSS3 之前,背景图片的尺寸是由图片的实际尺寸决定的。在 CSS3 中,可以规定背景图片的尺寸,这就允许我们在不同的环境中重复使用背景图片。

background-origin:属性规定背景图片的定位区域。
背景图片可以放置于 content-box、padding-box 或 border-box 区域。
div
{
background:url(bg_flower.gif);
background-repeat:no-repeat;
background-size:100% 100%;
-webkit-background-origin:content-box; /* Safari */
background-origin:content-box;
}

CSS3 允许您为元素使用多个背景图像。
body
{
background-image:url(/i/bg_flower.gif),url(/i/bg_flower_2.gif);
}

background-clip:规定背景的绘制区域。
值 描述 测试
border-box 背景被裁剪到边框盒。
padding-box 背景被裁剪到内边距框。
content-box 背景被裁剪到内容框。

CSS3 文本效果:
text-shadow:可向文本应用阴影。
word-wrap:允许您允许文本强制文本进行换行 - 即使这意味着会对单词进行拆分。
值 描述
normal 只在允许的断字点换行(浏览器保持默认处理)。
break-word 在长单词或 URL 地址内部进行换行。

新的文本属性
属性 描述 CSS
hanging-punctuation 规定标点字符是否位于线框之外。
punctuation-trim 规定是否对标点字符进行修剪。
text-align-last 设置如何对齐最后一行或紧挨着强制换行符之前的行。
text-emphasis 向元素的文本应用重点标记以及重点标记的前景色。
text-justify 规定当 text-align 设置为 "justify" 时所使用的对齐方法。
text-outline 规定文本的轮廓。
text-overflow 规定当文本溢出包含元素时发生的事情。
text-shadow 向文本添加阴影。
text-wrap 规定文本的换行规则。
word-break 规定非中日韩文本的换行规则。
word-wrap 允许对长的不可分割的单词进行分割并换行到下一行。

CSS3 字体:
在 CSS3 之前,web 设计师必须使用已在用户计算机上安装好的字体。
通过 CSS3,web 设计师可以使用他们喜欢的任意字体。
当您您找到或购买到希望使用的字体时,可将该字体文件存放到 web 服务器上,它会在需要时被自动下载到用户的计算机上。


您“自己的”的字体是在 CSS3 @font-face 规则中定义的。
使用您需要的字体:
在新的 @font-face 规则中,您必须首先定义字体的名称(比如 myFirstFont),然后指向该字体文件。
如需为 HTML 元素使用字体,请通过 font-family 属性来引用字体的名称 (myFirstFont);

CSS3 转换:transform
通过 CSS3 转换,我们能够对元素进行移动、缩放、转动、拉长或拉伸。
translate((50px,100px)元素从其当前位置移动,根据给定的 left(x 坐标和 top(y 坐标)

rotate(30deg)//元素顺时针旋转给定的角度。允许负值,元素将逆时针旋转

scale(2,4)元素的尺寸会增加或减少,根据给定的宽度(X 轴)和高度(Y 轴)参数
把宽度转换为原始尺寸的 2 倍,把高度转换为原始高度的 4 倍。

skew(30deg,20deg)元素翻转给定的角度,根据给定的水平线(X 轴)和垂直线(Y 轴)参数
围绕 X 轴把元素翻转 30 度,围绕 Y 轴翻转 20 度

matrix() 方法需要六个参数,包含数学函数,允许您:旋转、缩放、移动以及倾斜元素。
div
{
transform:matrix(0.866,0.5,-0.5,0.866,0,0);
-ms-transform:matrix(0.866,0.5,-0.5,0.866,0,0); /* IE 9 */
-moz-transform:matrix(0.866,0.5,-0.5,0.866,0,0); /* Firefox */
-webkit-transform:matrix(0.866,0.5,-0.5,0.866,0,0); /* Safari and Chrome */
-o-transform:matrix(0.866,0.5,-0.5,0.866,0,0); /* Opera */
}

transform-origin:设置旋转元素的基点位置:
div
{
transform: rotate(45deg);
transform-origin:20% 40%;

-ms-transform: rotate(45deg); /* IE 9 */
-ms-transform-origin:20% 40%; /* IE 9 */

-webkit-transform: rotate(45deg); /* Safari 和 Chrome */
-webkit-transform-origin:20% 40%; /* Safari 和 Chrome */

-moz-transform: rotate(45deg); /* Firefox */
-moz-transform-origin:20% 40%; /* Firefox */

-o-transform: rotate(45deg); /* Opera */
-o-transform-origin:20% 40%; /* Opera */
}

transform-origin: x-axis y-axis z-axis;

3D 转换:
CSS3 允许您使用 3D 转换来对元素进行格式化。
rotateX():元素围绕其 X 轴以给定的度数进行旋转
div
{
transform: rotateX(120deg);
-webkit-transform: rotateX(120deg); /* Safari 和 Chrome */
-moz-transform: rotateX(120deg); /* Firefox */
}

rotateY():元素围绕其 Y 轴以给定的度数进行旋转
div
{
transform: rotateY(130deg);
-webkit-transform: rotateY(130deg); /* Safari 和 Chrome */
-moz-transform: rotateY(130deg); /* Firefox */
}

Chrome 和 Safari 需要前缀 -webkit-。


函数 描述
matrix3d(n,n,n,n,n,n,
n,n,n,n,n,n,n,n,n,n) 定义 3D 转换,使用 16 个值的 4x4 矩阵。
translate3d(x,y,z) 定义 3D 转化。
translateX(x) 定义 3D 转化,仅使用用于 X 轴的值。
translateY(y) 定义 3D 转化,仅使用用于 Y 轴的值。
translateZ(z) 定义 3D 转化,仅使用用于 Z 轴的值。
scale3d(x,y,z) 定义 3D 缩放转换。
scaleX(x) 定义 3D 缩放转换,通过给定一个 X 轴的值。
scaleY(y) 定义 3D 缩放转换,通过给定一个 Y 轴的值。
scaleZ(z) 定义 3D 缩放转换,通过给定一个 Z 轴的值。
rotate3d(x,y,z,angle) 定义 3D 旋转。
rotateX(angle) 定义沿 X 轴的 3D 旋转。
rotateY(angle) 定义沿 Y 轴的 3D 旋转。
rotateZ(angle) 定义沿 Z 轴的 3D 旋转。
perspective(n) 定义 3D 转换元素的透视视图。

CSS3 过渡:
通过 CSS3,我们可以在不使用 Flash 动画或 JavaScript 的情况下,当元素从一种样式变换为另一种样式时为元素添加效果。
div
{
width:100px;
height:100px;
background:yellow;
transition:width 4s, height 4s;
-moz-transition:width 2s, height 2s, -moz-transform 2s; /* Firefox 4 */
-webkit-transition:width 2s, height 2s, -webkit-transform 2s; /* Safari and Chrome */
-o-transition:width 2s, height 2s, -o-transform 2s; /* Opera */
}

div:hover
{
width:200px;
height:200px;
transform:rotate(180deg);
-moz-transform:rotate(180deg); /* Firefox 4 */
-webkit-transform:rotate(180deg); /* Safari and Chrome */
-o-transform:rotate(180deg); /* Opera */
}
向宽度、高度和转换添加过渡效果:
div
{
transition: width 2s, height 2s, transform 2s;
-moz-transition: width 2s, height 2s, -moz-transform 2s;
-webkit-transition: width 2s, height 2s, -webkit-transform 2s;
-o-transition: width 2s, height 2s,-o-transform 2s;
}

属性 描述 CSS
transition 简写属性,用于在一个属性中设置四个过渡属性。
transition-property 规定应用过渡的 CSS 属性的名称。
transition-duration 定义过渡效果花费的时间。默认是 0。
transition-timing-function 规定过渡效果的时间曲线。默认是 "ease"。
transition-delay 规定过渡效果何时开始。默认是 0。

CSS3 动画
什么是 CSS3 中的动画?
动画是使元素从一种样式逐渐变化为另一种样式的效果。
请用百分比来规定变化发生的时间,或用关键词 "from" 和 "to",等同于 0% 和 100%。

属性 描述 CSS
@keyframes 规定动画。 3
animation 所有动画属性的简写属性,除了 animation-play-state 属性。
animation-name 规定 @keyframes 动画的名称。
animation-duration 规定动画完成一个周期所花费的秒或毫秒。默认是 0。
animation-timing-function 规定动画的速度曲线。默认是 "ease"。
animation-delay 规定动画何时开始。默认是 0。
animation-iteration-count 规定动画被播放的次数。默认是 1。
animation-direction 规定动画是否在下一周期逆向地播放。默认是 "normal"。
animation-play-state 规定动画是否正在运行或暂停。默认是 "running"。
animation-fill-mode 规定对象动画时间之外的状态。

CSS3 多列
通过 CSS3,您能够创建多个列来对文本进行布局 - 就像报纸那样!
column-count:属性规定元素应该被分隔的列数
column-gap:属性规定列之间的间隔
column-rule:属性设置列之间的宽度、样式和颜色规则

.newspaper
{
-moz-column-count:3; /* Firefox */
-webkit-column-count:3; /* Safari and Chrome */
column-count:3;

-moz-column-gap:40px; /* Firefox */
-webkit-column-gap:40px; /* Safari and Chrome */
column-gap:40px;

-moz-column-rule:4px outset #ff0000; /* Firefox */
-webkit-column-rule:4px outset #ff0000; /* Safari and Chrome */
column-rule:4px outset #ff0000;
}

属性 描述 CSS
column-count 规定元素应该被分隔的列数。
column-fill 规定如何填充列。
column-gap 规定列之间的间隔。
column-rule 设置所有 column-rule-* 属性的简写属性。
column-rule-color 规定列之间规则的颜色。
column-rule-style 规定列之间规则的样式。
column-rule-width 规定列之间规则的宽度。
column-span 规定元素应该横跨的列数。
column-width 规定列的宽度。
columns 规定设置 column-width 和 column-count 的简写属性。

CSS3 用户界面
resize:属性规定是否可由用户调整元素尺寸
box-sizing:属性允许您以确切的方式定义适应某个区域的具体内容
content-box,border-box,inherit
outline-offset:属性对轮廓进行偏移,并在超出边框边缘的位置绘制轮廓
分享到:
评论

相关推荐

    精通CSS笔记——是学习精通CSS的一些感悟

    在深入探讨CSS的世界之前,我们首先要理解CSS(Cascading Style Sheets)的含义。它是一种样式表语言,用于描述HTML或XML(包括如SVG、MathML等各种XML方言)文档的呈现。CSS控制着网页的布局,使内容更具视觉吸引力...

    html5模板-志愿者主题CSS3网站模板.zip

    CSS3的媒体查询(Media Queries)实现了响应式设计,使网站能适应不同设备的屏幕尺寸。边框半径(border-radius)、阴影(box-shadow)和渐变(gradient)等功能提供了丰富的视觉效果,而Flexbox和Grid布局系统则...

    使用CSS3来代替JS实现交互

    【CSS3和JS】 对于CSS了解的同学都知道,CSS的实现是最...先来看个例子:可以更好的体现我这次对于CSS的深刻感悟 <style> body{background:#f4f4f4;margin:0;} /*list*/ .list__con{} .list__con .box{backgr

    html,css,js

    CSS3的新特性,如响应式设计(媒体查询`@media`)、过渡(`transition`)、动画(`animation`)、以及Flexbox和Grid布局系统,也将是重点讲解内容。 JavaScript是一种动态编程语言,用于实现网页的交互性和功能。...

    编写CSS的一些感悟分享

    在CSS的编写过程中,我们经常会面临布局设计和样式设置的挑战。从分享的内容来看,作者在实践中积累了一些宝贵的经验,这些经验对初学者和有一定经验的开发者都极具启发性。 首先,作者提到用ID来定义整个页面的...

    css.rar 参考下载

    最后,“CSS感言.doc”可能包含作者在实践CSS过程中的一些个人见解和心得。这可能包括如何有效地组织和编写CSS代码,以保持代码的可维护性和可读性,例如遵循模块化、BEM(Block Element Modifier)命名规则,或者...

    基于JavaScript、Java、CSS、HTML的“xianqu”生活感悟分享平台设计源码

    本项目是一款集JavaScript、Java、CSS、HTML于一体的“xianqu”生活感悟分享平台设计源码,包含371个文件,涵盖71个JAR文件、57个JPG图片、50个PNG图片、36个GIF动画、34个Java源文件、27个CLASS字节码文件、19个...

    CSS 学习心得

    不论页面的问题大小都统统交给他们解决,这样不仅影响了自己的工作效率,还给UED的同事带去不少麻烦,正好这几天工作不是很紧张,在http://www.w3school.com.cn/index.html网站上浏览了一些关于CSS的资料,感觉CSS比...

    jQuery客户感言展示特效.zip

    客户感言1 客户感言2 <!-- 更多感言项... --> ``` 接下来是CSS样式,通过定位和隐藏超出部分,我们可以实现滑动的基础布局: ```css .testimonial-slider { overflow: hidden; } .testimonial-item { float...

    jQuery卡片式叠加图文感言布局

    通过CSS3的新特性,如过渡(transition)、动画(animation)和变换(transform),可以实现卡片的平滑过渡效果,比如卡片在叠加时的淡入淡出、缩放和位移。同时,CSS还能够控制图文的排列方式,例如图片在左、文字...

    Web大学生网页作业成品 :黑色主题个人博客网站设计与实现(HTML+CSS+JavaSpt).md

    - **CSS3**: 用于网页样式的定义和美化,通过CSS3可以实现更加丰富的视觉效果和更复杂的布局。 - **JavaScript (JS)**: 提供了交互性和动态功能的支持,例如动态轮播、表单验证等。 - **DIV + CSS**: 主流的网页布局...

    咖啡色调个人博客CSS模板_咖啡 咖啡色 二栏 简单 个人 博客.rar

    在颜色的选择上,咖啡色系列能够引起人们关于舒适、安静和沉思的联想,为博主分享生活点滴、旅行见闻、美食体验或个人感悟提供了一个充满情感的背景。 CSS,即层叠样式表,作为网页设计中不可或缺的技术之一,使得...

    学习java实训感言

    一些实训学习java的感言:选择了java方向,培训从java基础的类开始学,将java的概念重头到尾的学了一遍,接着又学习了web方面,从javascript,html,css,然后用到工具dw开发网页。 并且我们在学校进行了专业的java...

    Testimonial-grid:练习CSS网格和Sass的小项目

    在网页设计中,感言部分通常需要整洁、有序的展示,这正是CSS网格系统的用武之地。通过CSS网格,我们可以轻松定义行和列,适应不同屏幕尺寸,确保在各种设备上都能有良好的视觉效果。同时,Sass的使用可以提高代码的...

    社交网络用户行为分析与讯息管理江港实训感悟.pdf

    3. HTML、CSS:HTML(HyperText Markup Language)是用于创建网页的标准 markup 语言,CSS(Cascading Style Sheets)是用于设置网页样式的语言。 社交网络用户行为分析系统的应用场景包括: 1. 精准营销:系统...

    PJBlog3 塵世情懷模板

    1. **主题文件**:这通常是一系列PHP文件,其中包含了PJBlog3系统所需的主题设置和样式。这些文件将定义模板的布局、菜单、侧边栏、页脚等部分。 2. **CSS样式表**:一个或多个.css文件,用于定义模板的颜色、字体...

    进军前端-个人感悟

    3. JavaScript:动态脚本语言,让网页具备交互性,涉及DOM操作、事件处理、AJAX异步请求等。 4. 前端框架:如React、Vue、Angular,它们提供了高效的开发工具和组件化体系,简化了复杂项目的管理。 其次,"demo.zip...

    网页设计实习心得感悟___五篇.docx

    网页设计实习心得感悟 网页设计实习是一段宝贵的经历,它为高校生提供了实践技能和理论知识相结合的机会。在实习期间,学生能够深入了解网页设计的工作流程,掌握网页制作的基本技巧,如使用Photoshop进行图片切片...

Global site tag (gtag.js) - Google Analytics