`
ice-cream
  • 浏览: 328215 次
  • 性别: Icon_minigender_2
  • 来自: 上海
社区版块
存档分类
最新评论

提升你设计水平的CSS3新技术(下)

    博客分类:
  • Css3
阅读更多

 

提升你设计水平的CSS3新技术(上)

8. 圆角(边框半径)

Border-radius 无需背景图片就能给HTML元素添加圆角。现在,它可能是使用最多的CSS3属性了,很简单的原因是使用圆角比较好而且不会对设计和可用性有冲突。

不同于添加Javascript或多于的HTML标签,仅仅需要添加一些CSS属性并从好的方面考虑。这个方案是清晰的和比较有效的,而且可以让你免于花费几个小时来寻找精巧的浏览器方案和基于Javascript圆角。

Sam Brown's blog categories
Sam Brown的博客在标题、分类和链接处使用了border-radius.

Sam Brown在他的博客的标题、分类、链接和div中大量的使用了border-radius属性。使用图片来实现该效果将会比较费时的,这是在项目中使用CSS3属性是提高开发效率的重要步骤的原因之一

为了给类别链接添加圆角,Sam 使用了下面的CSS片段:

h2 span {
	color: #1a1a1a;
	padding: .5em;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	}

我们可以做的更进一步,添加原始的CSS3 属性和Konqueror 属性扩展,如下:

h2 span {
    color: #1a1a1a;
    padding: .5em;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    -khtml-border-radius: 6px;
    border-radius: 6px;
    }

如果我们想在我们的元素中的某个特定的角上应用此属性,我们可以单独的指定每个角:

div {
    -moz-border-radius-topright: 6px;
    -moz-border-radius-topleft: 6px;
    -moz-border-radius-bottomright: 6px;
    -moz-border-radius-bottomleft: 6px;
    -webkit-border-top-right-radius: 6px;
    -webkit-border-top-left-radius: 6px;
    -webkit-border-bottom-right-radius: 6px;
    -webkit-border-bottom-left-radius: 6px;
    border-top-right-radius: 6px;
    border-top-left-radius: 6px;
    border-bottom-right-radius: 6px;
    border-bottom-left-radius: 6px;
    }

浏览器支持: border-radius只有所有版本的IE浏览器和Opera不支持,Webkit和Gecko核心的浏览器都支持。

扩展阅读:

9. 边框图片

border-image 属性允许你在元素的边框上设定图片, 让你从通常的solid, dotted 和其它边框样式中解放出来。该属性给设计师一个更好的工具,用它可以方便的定义设计元素的边框样式,比background-image 属性(对高级设计来说) 或枯燥的默认边框样式更好用。我们也可以明确的定义一个边框可以被如何缩放或平铺。

SpoonGraphics blog's border-image
SpoonGraphics 博客为它的图片边框使用了border-image 属性。

SpoonGraphis blog中,border-image被用于图片边框,如下所示:

#content .post img {
    border: 6px solid #f2e6d1;
    -webkit-border-image: url(main-border.png) 6 repeat;
    -moz-border-image: url(main-border.png) 6 repeat;
    border-image: url(main-border.png) 6 repeat;
    }

要想定义border-image,我们必须指定图片地址,图片的那部分将被剪切并用于元素的每一个边上,以及图片是否被缩放或平铺。

为了制作一个使用下面的图片作为边框的div ,我们应该使用下面的代码(我们将为这个例子添加Opera 和Konqueror 支持):

Image used as border-image

div {
    border-width: 18px 25px 25px 18px;
    -webkit-border-image: url(example.png) 18 25 25 18 stretch stretch;
    -moz-border-image: url(example.png) 18 25 25 18 stretch stretch;
    -o-border-image: url(example.png) 18 25 25 18 stretch stretch;
    -khtml-border-image: url(example.png) 18 25 25 18 stretch stretch;
    border-image: url(example.png) 18 25 25 18 stretch stretch;
	}

该属性的最后一个值可以是stretch (默认), round (只有一个平铺了整数倍的图片被填充在允许的地方) 或repeat。在我们的例子中,上下左右边框图片被拉伸。如果我们只想顶部和底部边框被拉伸,我们可以使用下面的CSS:

div {
    (...)
    border-image: url(example.png) 18 25 25 18 stretch repeat;
	}

我们可以可以单独的指定每一个角,如果我们想为每一个角使用不同的图片:

div {
    border-top-image: url(example.png) 5 5 stretch;
    border-right-image: url(example.png) 5 5 stretch;
    border-bottom-image: url(example.png) 5 5 stretch;
    border-left-image: url(example.png) 5 5 stretch;
    border-top-left-image: url(example.png) 5 5 stretch;
    border-top-right-image: url(example.png) 5 5 stretch;
    border-bottom-left-image: url(example.png) 5 5 stretch;
    border-bottom-right-image: url(example.png) 5 5 stretch;
    }

如果浏览器不支持border-image 属性,它将无视这些属性,并只应用定义的其它边框属性,比如border-widthborder-color.

浏览器支持: border-image 目前只有Webkit核心浏览器支持。不太确定Firefox的下一个版本是否支持。

扩展阅读:

10. 盒阴影

box-shadow 属性可以对HTML元素添加阴影 而不用额外的标签或背景图片。类似text-shadow 属性,它增强设计的细节;而且因为它不影响内容的可读性,随意他可以是增加那种额外感觉/效果的一种很好的方法。

10to1 navigation
10to1 为它的导航北京和hover状态使用了box-shadow 属性.

10to1 为其导航区域增加的一个简单的阴影并将该属性应用于导航链接的hover效果:

#navigation {
	-webkit-box-shadow: 0 0 10px #000;
	-moz-box-shadow: 0 0 10px #000;
	}
	#navigation li a:hover,
	#navigation li a:focus {
	-webkit-box-shadow: 0 0 5px #111;
	-moz-box-shadow: 0 0 5px #111;
	}

box-shadow属性可以用多个值:水平偏移、垂直偏移、模糊半径、伸展半径和阴影颜色。水平和垂直偏移和阴影色使用的最多。

在一个div上应用红色阴影,右边和下边偏移4px,无模糊,我们可以使用下面的代码:

div {
    -moz-box-shadow: 4px 4px 0 #f00;
    -webkit-box-shadow: 4px 4px 0 #f00;
    box-shadow: 4px 4px 0 #f00;
    }

浏览器支持: box-shadow目前只有Webkit核心浏览器支持,但是即将发布的Firefox 3.5 也将提供很好的支持。

扩展阅读:

11. 盒子大小

根据CSS 2.1 规范,在计算盒子的总大小的时候,元素的边框和padding应该被加入到宽度和高度之中的。但是众所周知,旧的浏览器却以它们自己的非常有“创意”的方式来解释这个规范。box-sizing属性允许你指定浏览器如何计算一个元素的宽度和高度

WordPress input and textarea tags
WordPress 在控制面板的所有的输入框元素中使用border-box 属性。

WordPress 后台区域在它的所有text类型的input标签和textarea标签上使用了该属性:

input[type="text"],
	textarea {
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	}

第三个属性(-ms-box-sizing) 只有在Internet Explorer 8下有效。通过其他选择器,WordPress 的样式表同样添加了Konqueror 属性: -khtml-box-sizing

box-sizing 属性可以两个值中的一个:border-boxcontent-box。 Content-box如CSS2.1中的定义的那样渲染宽度。Border-box 从设定的宽度和高度中扣除padding和边框(如老式浏览器那样。)。

浏览器支持: box-sizing 被IE8、Opera、Gecko核心和Webkit核心浏览器支持。

扩展阅读:

12. 媒体查询

媒体查询(media queries)可以让你为不同的设备基于它们的能力定义不同的样式。比如,在可视区域小于480像素的时候,你可能想让网站的侧栏显示在主内容的下边,这样它就不应该浮动并显示在右侧了:

#sidebar {
	float: right;
	display: inline; /* IE Double-Margin Bugfix */
	}
 
@media all and (max-width:480px) {
	#sidebar {
		float: none;
		clear: both;
		}
	}

你也可以指定使用虑色屏的设备:

a {color: grey;}
@media screen and (color) {
	a {color: red;}
}

潜力是无限的。这个属性是很有用的因为你你不在需要必须为不同的设备写独立的样式表了,而且你也无需使用JS来确定每个用户的浏览器的属性和功能。一个实现一个灵活的布局的更加流行的基于Javascript的方案是使用智能的流体布局,让布局对于用户的浏览器分辨率更加灵活。

浏览器支持: 媒体查询被基于webkit核心的浏览器和Opera支持。Firefox将在3.5版本中支持它。IE目前不支持这些属性而且在将来的版本中,也没有支持的计划。

扩展阅读:

13. 语音

CSS3的语音模块CSS3可以让你为屏幕阅读者指定语音样式。你可以控制语音的不同设置,比如:

  • voice-volume
    使用从0到100的数字(0 即静音)、百分数或关键词(silent, x-soft, soft, medium, loudx-loud等)来设置音量。
  • voice-balance
    控制来自哪个声道(如果用户的音箱系统支持立体声)。
  • Speak
    指示屏幕阅读器阅读相关的文字、数字或标点符号。可用的关键词为none, normal, spell-out, digits, literal-punctuation, no-punctuationinherit.
  • Pauses and rests
    在一个元素的被读完之前或之后设定暂停或停止。你可以使用时间单位(比如, “2s” 表示2 秒钟) 或关键词(none, x-weak, weak, medium, strongx-strong)。
  • Cues
    使用声音限制特定元素并控制器音量。
  • voice-family
    设定特定的声音类型和声音合成(就像font-family)。
  • voice-rate
    控制阅读的速度。可以设置为百分数或关键词: x-slow, slow, medium, fastx-fast.
  • voice-stress
    指示应该使用的任何重音(强语气),使用不同的关键词: none, moderate, strongreduced.

比如,告诉屏幕阅读器使用男声读取所有的h2 标签,用左边的喇叭,用软调按照指定的声音,可以像下面这样指定样式:

h2 {
	voice-family: female;
	voice-balance: left;
	voice-volume: soft;
	cue-after: url(sound.au);
	}

不幸的是,这个属性现在只有非常少的支持,但是显然值得关注因为我们可以在将来提高我们网站的易用性。

浏览器支持: 现在,只有Opera 浏览器(Windows XP and 2000)支持语音模块的部分属性。为了使用它们,需要使用-xv- 前缀,比如-xv-voice-balance: right

扩展阅读:

结尾

CSS3 属性可以极大的提高你的工作流,让一些最耗时的CSS任务不费吹灰之力就能搞定,并且可以使用更好、更简洁和更轻的代码标签。一些属性尚未被广泛的支持,甚至是最新的浏览器,但这并不意味着我们不能用它们进行试验或者为使用先进浏览器的用户更高级的功能和CSS样式。

在这点儿上,请记住,培养我们的用户 也同样是有用和必须的:网站无需看起来在每个浏览器里都要保持一致,而且如果一个差异不(负面)影响美学和网站的可用性,它就应该是被考虑的。如果我们继续浪费大量的时间和金钱以使每个细节绝对一致(而不是采用更灵活的和未来导向的方案), 用户将没有升级他们的浏览器的任何需要/动机,这样我们就不得不在旧的浏览器变为古董级浏览器以及强大的现代浏览器变为标准之前等待很长的时间

我们试验和使用新的CSS3属性越早,它们就被流行的浏览器支持的更早,我们也就能够更早的广泛使用它们。

 

推荐阅读及资源:

关于原作者

Inayaili de León 是一个葡萄牙的网页设计师。她对网页设计和前端编码真的非常感兴趣,而且喜欢漂亮和简洁的网站。她居住在伦敦。你可以在Web Designer Notebook 上看到她的更多文章,并follow her on Twitter .

 

 

原文:用CSS3将你的设计带入下个高度
译自:Take Your Design To The Next Level With CSS3
版权所有,转载请注明出处,多谢!!

  • 大小: 35 KB
  • 大小: 45.5 KB
  • 大小: 8.7 KB
  • 大小: 35.2 KB
  • 大小: 20.4 KB
分享到:
评论

相关推荐

    CSS权威指南 css彻底设计研究 HTML5和CSS3实战 HTML5与CSS3设计模式

    此外,通过实际案例,读者将学习如何结合CSS3的新功能,如多列布局、渐变、阴影、边框半径、转换和动画,以提升网页的视觉效果和用户体验。 最后,"HTML5与CSS3设计模式"关注的是这两种技术的创新设计思路。设计...

    纯CSS3用户卡片设计效果

    【纯CSS3用户卡片设计效果】是一种利用现代CSS3特性实现的网页元素设计技术,它无需依赖JavaScript或者其他库,仅通过CSS3就能创造出引人注目的用户体验。在本设计中,用户卡片作为一种常见的UI组件,被赋予了动态的...

    HTML5 CSS3 chm中文参考手册_html5_CSS3_css3.chm_参考手册_

    HTML5和CSS3是现代网页开发的两大核心技术,它们极大地扩展了网页的展现力和交互性。本资源提供了一份详尽的中文参考手册,旨在帮助开发者...这份手册的分享对于提升开发者的技术水平和推动行业进步具有积极的意义。

    jQuery+CSS3+html5水平时间轴插件

    **CSS3** 是CSS的最新版本,它引入了许多新的特性和功能,例如选择器、过渡效果、动画、多列布局等。在这个插件中,CSS3的过渡和动画特性被充分利用,使得时间轴的展开和收起过程流畅自然,同时提供了丰富的样式定制...

    图解Css3核心技术和案例源代码

    《图解Css3核心技术和案例源代码》是...通过学习和实践《图解Css3核心技术和案例源代码》中的实例,你可以全面掌握CSS3的各种新特性,从而提升网页设计和开发的能力。结合源代码实践,将有助于加深理解和提高编程效率。

    CSS3中的5个有趣的新技术

    总结起来,CSS3中的这些新技术为网页设计师提供了更多创意空间,让网页看起来更加现代化和专业。虽然不是所有浏览器都完全支持这些特性,但随着浏览器更新迭代,这些功能逐渐成为标准,开发者应该熟悉并适当地在项目...

    CSS3实战与案例

    总的来说,《CSS3实战与案例》这本书将带你探索CSS3的深度和广度,通过丰富的实例和源代码,帮助你掌握这些技术,并将其应用于实际项目中,提升你的Web设计水平。无论你是初学者还是经验丰富的开发者,都能从中...

    jQuery html5 css3图片翻转特效_水平垂直360°

    "jQuery html5 css3图片翻转特效_水平垂直360°"是一个利用现代Web技术实现的创新交互功能,它允许用户从不同角度查看图像,从而增加网站的互动性和趣味性。下面我们将详细探讨这个主题涉及的知识点。 1. **jQuery*...

    前端体验设计——HTML5+CSS3终极修炼

    本书聚焦于HTML5与CSS3这两项核心前端技术,旨在帮助读者掌握最新的Web设计与开发方法,全面提升技术水平与设计视野。 #### 二、核心知识点解析 ##### 1. HTML5基础与进阶 - **语义化标签**:HTML5引入了许多新的...

    HTML与CSS前台页面设计

    HTML(HyperText Markup Language)和CSS(Cascading Style Sheets)是网页开发的基石,它们共同构成了前端页面设计的...通过不断学习和实践,你可以进一步提升页面设计的水平,满足用户对视觉效果和交互体验的需求。

    Html5+CSS3特效整合

    本资源包“Html5+CSS3特效整合”汇集了一系列使用这两种技术实现的前沿特效,旨在帮助开发者提升网站用户体验和设计水平。 1. **全屏滑块HTML5实现效果**: 全屏滑块是现代网站中常见的元素,HTML5的离线存储、...

    html5+css3实战 例子

    HTML5和CSS3是现代网页开发的两大核心技术,它们的结合使用极大地提升了Web设计的...通过阅读这本书,开发者不仅可以了解HTML5和CSS3的基础知识,还能学习到如何在项目中有效应用这些新技术,从而提升自己的专业素养。

    CSS3、1000+案例.zip

    【CSS3】是一种强大的网页样式语言,用于定义网页元素的布局、颜色、字体和其他视觉表现。相较于CSS2,CSS3引入了...通过研究和模仿这些实例,开发者可以提升自己的CSS3技术水平,创造出更具吸引力和互动性的网页设计。

    纯CSS3用户登录界面设计

    总结来说,纯CSS3用户登录界面设计是一个综合应用CSS3新特性的实例。通过熟练掌握选择器、布局、过渡动画和背景效果,我们可以创建出既美观又实用的登录界面,满足不同场景的需求。同时,结合“星空”这一主题,可以...

    CSS3 For Web Designers

    ### CSS3 For Web Designers #### 使用CSS3的今日实践 ...通过阅读这本书,读者不仅能够掌握CSS3的基本语法和用法,还能学会如何将其巧妙地应用于实际项目中,从而提升自己的设计水平和技术实力。

    HTML+CSS+JS网页设计期末课程大作业 web前端开发技术 web课程设计 网页规划与设计.zip

    HTML、CSS和JavaScript是网页设计的核心技术,它们构成了web前端开发的基础。...通过这个课程大作业,学生不仅能够提升技术水平,还能培养项目管理和团队协作能力,这对他们未来的职业发展具有重要意义。

    HTML5+CSS3+JavaScript网页设计

    HTML5、CSS3和JavaScript是构建现代网页设计的三大核心技术,它们共同构成了网页内容的结构、样式和交互性。...记得保持对新技术的热情,不断提升自己的技术水平,因为前端开发领域始终在快速发展。

    多种卡片设计css3模板下载-card 卡片 设计 html5 css3 代码.rar

    无论是新手开发者还是经验丰富的设计师,都可以从中获取灵感和实用技巧,提升网页设计的水平。通过深入理解和实践这些模板,你可以更好地掌握前端开发中的卡片设计,为用户提供更优秀的交互体验。

    css3核心技术与案例实战

    总的来说,《CSS3核心技术与案例实战》是一本覆盖全面、实践性强的CSS3学习资源,无论你是初学者还是有一定基础的开发者,都能从中受益,提升自己的CSS3技术水平。通过阅读和实践,你可以学会利用CSS3创造出更具吸引...

Global site tag (gtag.js) - Google Analytics