像素是计算机屏幕上的不可缩放的点,而一个 em 就是一个字大小的方块。由于字体大小的变化, em 代表用户喜欢的文字大小的相对单位。
采用印刷式的固定设计方案或许要容易些,因为如果尺寸不变,则考虑的东西就相对较少。可是如果采用d性的设计方法,就可以充分利用电脑的显示器和浏览器。
也许你想你的网站以某种特定的方式显示,但是你的用户想看到的可能不一样。任何强加于用户的东西都不利于易用性,从而对网站的成功造成损害。
为了理解d性设计,我们必须首先来看看一个似乎与此无关的问题 - 指定文字大小的几种方式。
d性文本
显然文字是最容易实现的d性设计的。能够设定喜欢的文字大小是用户最常见的要求,因此不可忽视。
亲和力指的并不只是关于盲人和屏幕阅读器。还有许多人虽然不是盲人,但是有视力障碍 - 你我变老时就会成为他们的一员。使网站变得更具亲和力的一个最简单的方法就是允许用户改变文字大小;拒绝提供这样的选择就剥夺了用户的主导权,很可能使用户无法舒适地阅读。
如果设计者使用像素为单位指定文字大小,大多数的用户将无法缩放文字,因为 Internet Explorer 改变文字大小的方式与别的浏览器不同。Mozilla 和 Opera 可以缩放已经设定像素大小的文字,而Windows 下的IE却不能。
em 存在的问题
Em 似乎是进行文字相对大小设定时的单位,浏览器默认的文字高度是16像素,对大多数设计者来说太大了,不合他们的口味。要使用 em,设计者一般将文字的初始大小设为小于 1em。
例如:
body { font-size: 0.8em}
h1 { font-size: 2em}
p { font-size: 1em}
看起来似乎可行,但有一个问题 - 如果你在 IE 中将“文字大小”设为“较小”或“最小”,文字就会小得难以阅读。由于 IE 如此普及, em 似乎不是可行的选择。
得出的。 Owen Briggs 测试了264种不同的文字缩放方法并演示了 em 之类的相对单位行不通。许多设计人员现在都用像素为单位指定文字大小,不是出于精确控制网页外观的需要,而是似乎没有更为合理的其他选择。
如此看来,要么是难看的大字体,要么无法缩放,好像无法两全。别着急,接着读下去。
另一种“大字体”后备样式
在与无法缩放的像素所带来的亲和力问题的战斗中,许多作者在他们的网页上使用了一种的技术,可通过网页上的一个链接进行切换。
这种方法固然不错,但是如果和相对文字大小的措施(比如
CSS 关键词
Font-size 的关键词(xx-small, medium, x-large,等等)好像就是答案。在 IE 中,当用户选择“较大”或“最大”时文字会变大,选择“较小”或“最小”时文字会变小,一直到合适的大小。与其他的d性设计方法不同,使用关键字的好处是当对文字进行缩放时,永远不会使文字实际像素大小低于某个值,所以无论用户如何选择文字大小,都应当有良好的可读性。
在 ALA 的对关键字有更详尽的解说,这种方法的最好的示例也许就是你正在阅读的这篇文章。(在最近一次的改版之前,ALA 使用了后备的“大字体”样式切换,一个样式表使用像素指定文字大小,另一个用的是基于关键字的相对大小方法。)
百分比使得 em 可行
Em 之所以可行是因为通过设定初始文字的百分比,可以很容易避免文字过小的问题。虽然其原理并非显而易见,但的确可行。当采用这种方案时,IE 文字大小各档设置之间的间隔就不会显得生硬,设计者可以精确设置初始文字大小,使得在“较小”和“最小”时仍然得到较好的可读性。这样有使 em 有了用武之地。(甚至于 Briggs 现在也更.)
例如:
body { font-size: 80%}
h1 { font-size: 2em}
p { font-size: 1em}
不用关键字而采用 em 的好处是你可以用 em 来指定全部布局的尺寸,它可以随着文字的大小按比例缩放。
d性布局
对设计者来说,比d性字体更困难的是彻底的相对布局 - 如果用 em 来设定布局的尺寸事情就容易了。
让布局具有d性,使之随着用户改变文字大小时自动适应,这好像有些多余甚至毫无必要。但是既然你让文字可以伸缩,那么让包容文字的布局也随之伸缩也是顺理成章的事。
另外,如果用户选择了较大的字体,则周围的空间应当会随之按比例增加,保持了“设计者”选择的比例,使文章容易阅读。
这种方案的另一个好处是可以避免不希望的文字换行。如果一个窄的栏目宽度以像素来定义,当其中的文字变大时,可能会打乱整个布局。采用文字大小比例来指定栏目宽度就可避免这个问题。
关于该方案的一个例子请看 CSS Zen Garden 上的作品 。
太宽了!
将网页的初始文字大小指定为 100% 以后,在 IE 的“中等”字体下,36em 的宽度应该是 576 个像素(作为参考,ALA 的宽度为600个像素),在“最大”的字体下,36em 应当增加到 768 个像素(Windows 下 IE 6 的测试结果)。如果再大一点,在 800 像素宽的屏幕、“最大”号字体下就可能会显得太宽了。
CSS 对这个问题的解决方案是 max-width 属性,它可以指定某个元素的最大宽度。不幸的是 Internet Explorer 不支持(不知有谁想过没有?)。
另一个解决方案就是采用流动式布局,也就是说根本不指定内容区域的宽度,让文字自然流动,充满屏幕宽度(采用了这种方案)。许多人不接受这种方案,因为在宽屏幕下的可读性不好,但对于移动设备这样的小屏幕非常合适。
如果你准备采用d性布局方案,在指定边界或者位图之类的由像素构成的对象时,仍然要以像素为单位,这可能会和基于文字大小关系发生冲突;但这不应成为不采用d性布局的理由。
使图形d性化
用相对大小来设置位图的尺寸会导致灾难性的后果。对付这个问题可以这样做 - 维持图形原有的解析度不变,将它裁剪到合适的大小。
通过更换背景图片可以就可做到。这里是一个标题元素的例子,你也可以采用其他的图片替换技术:
h1 { font-size: 1emwidth: 10emheight: 100pxtext-indent: -1234embackground-image: url(whatever.jpg)}
或者(正如所做的那样),你可以将图片包含在一个容器,比如一个有下面样式的 DIV 中:
div { width: 10emoverflow: hidden}
本文中提到的许多d性设计方法都可以在 中看到。
你好 可以如下设置 比如 你只想要他宽度为100px 自动换行 那么可以如下<div style="width:100pxheight:60pxfont:12px/20px 宋体">
在这里写入文字内容 每行高20px 自动会换行
</div>
希望能帮到你谢谢
HTML输入框输入后变成文本是通过输入后失去焦点,更改为label嵌套input来实现的。
实现思路:当输入文本后,隐藏input对象,然后把文本内容追加到label标签内。
html语句问题,输入框文本换行问题:
把input换成下面这个吧,支持多行的标签,可自动换行:
1.<textarea id="ta1" style="width:500pxheight:300px" value="我可以自动换行"></textarea>。
2.把textarea当成input一样使用就可以了,也是可以表单提交的。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)