02
三 10
宽度自适应的输入框
YUI中有一种布局思想:栅格决定宽度,内容决定高度,今天讨论的是自适应宽度的输入框,先上代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>宽度自适应输入框</title>
<link rel="stylesheet" href="http://yui.yahooapis.com/3.0.0/build/cssreset/reset-min.css">
<style>
.col{padding:10px;width:500px;background-color:yellow;}
.fluid-input{display:inline-block;width:100%;overflow:hidden;}
.fluid-input-inner{display:block;padding-right:10px;#zoom:1;}
.fluid-input .text, .fluid-input textarea{border:2px #ccc solid;padding:3px;width:100%;}
.fluid-input textarea{height:300px;}
</style>
</head>
<body>
<div class="col">
<b class="fluid-input"><b class="fluid-input-inner"><input class="text" type="text"></b></b>
<b class="fluid-input"><b class="fluid-input-inner"><textarea></textarea></b></b>
</div>
</body>
</html>
简单说一下原理:
为了有较好的体验,input[type='text']及textarea一般会有border值及padding值(鄙视某些padding设为0滴淫儿),利用如下公式:
.fluid-input-inner{padding-right:输入框左边框 + 输入框右边框 + 输入框左padding + 输入框右padding}
让输入框继承fluid-input-inner的宽度即可实现自适应;而IE6有个宽度超出自动撑开的bug,故再多套一层fluid-input,宽度100%,溢出隐藏即可。
col宽度随意,在宽度自适应布局中默认为auto,这里方便演示定了宽度。
这里由内而外解说,不过命名是由外而内的。
更进一步
focus时border变为4px咋整?
问的好(其实是偶自己在问),输入框focus后增加class=”focus”,即变为:
<textarea class="focus"></textarea>
CSS:
.focus{position:relative;left:-2px;border-width:4px !important;}
———————— 乡民问答分隔线 ————————-
美女@jeannewoo反馈了个bug,IE6下textarea输入文字的时候就自己撑开了(昨晚下班路上@ivane也跟我说过,不过我没当回事,嘿~),我试了一下果真如此,解决方法很简单:触发fluid-input-inner的hasLayout即可。
美女又问为什么用s,我想了一下换成了b,想知道原因么?看这个 http://www.youtube.com/watch?v=vjLdp5tJM0c
08
二 10
跨浏览器的Firebug
标题党一把,哇哈哈哈哈~
Firebug Lite越来越好了,Chrome的Firebug Lite扩展其实就是Firebug Lite(扩展的缺点是要安装),但是我发现身边的一些人(包括大牛)对其还不太了解,下面简单介绍一下
Firebug Lite安装及使用
- 用需安装Firebug Lite的浏览器打开Firebug Lite安装页面
- 设置浏览器显示书签栏
- 将此链接Firebug Lite 1.3Xb拖拽到浏览器的书签栏(也可直接拖拽此链接,可能会被RSS阅读器过滤,请打开本博查看)
- 打开要调试的页面
- 点击刚才加入书签栏的Firebug Lite 1.3Xb调出即可(为远程调用要稍许等待)
注:
- 以上方法使用于大部分浏览器(Firefox/Chrome/Safari/Opera自不在话下),可能各浏览器多书签栏的叫法有不同
- IE等不能拖拽到收藏夹栏可以通过右键添加
- 可自行制作离线版本,详见Firebug Lite安装页面
- 复杂的页面调试不了…
另一个比较常用的书签工具为大牛Steve Souders的SpriteMe,用于自动生成css sprite图片:
SpriteMe安装及使用
同Firebug Lite类似,将这个链接SpriteMe(可能会被RSS阅读器过滤,请打开本博查看)拖拽到书签栏即可。
让人欣喜的是,和Firebug Lite一样是开源的,可在SpriteMe项目主页下载源码并建立离线版本。
下面是来自youtube的视频介绍(后半段为SpriteMe介绍):
05
二 10
IE6/7下划线对不齐bug
这篇帖子《关于IE下英文字体跟中文字体不能对齐的根源以及解决办法》说的已经很详细了,不过不止中英文混合才会出现这个bug,比如《Internet Explorer: Broken Underlines》。
解决方法一般有以下几种:
- 对下划线元素使用宋体,缺点是宋体的英文数字比较难看,我个人也比较鄙视这种做法
- 触发下划线元素的hasLayout,缺点是inline元素会变成inline-block元素,折行时会整块掉下来
- 使下划线元素浮动,缺点是inline元素变成block元素,而且还要清除浮动
- 去除下划线元素相邻元素(相邻元素的子元素或父元素等等)的vertical-align(或重写为baseline),垂直居中用position:relative结合top来实现
在使用inline-block元素做sprite容器时经常会遇到这个问题,2、4是比较好的方案,记得要分清楚使用场合哦~
当然IE6下还会出现行高失效bug,old9给出了一种方法《A fix to the IE6 line-height/replaced element bug》,不过在某些追求精确到像素的情况下还是用PIE的方法《Microsoft Internet Explorer 6: Line-height / Replaced Element Bug》比较好。
另外,使用vertical-align:middle来垂直居中在各浏览器中差异也比较大,使用时需谨慎,而用数值则好多了,推荐阅读old9的《CSSTDG读书笔记七》
24
一 10
Web标准中的特殊字符»
在最开始学习web标准的时候有这么一条:
把所有<和&特殊符号用编码表示 :
任何小于号(<),不是标签的一部分,都必须被编码为& l t ; 任何大于号(>),不是标签的一部分,都必须被编码为& g t ;
任何与号(&),不是实体的一部分的,都必须被编码为& a m p;
注:以上字符之间无空格。
而在我们平时的工作中经常会遇到这种情况:
更多>>
国内的同行大多是写两个大于号>>或者干脆就写>>(更夸张的是有人为了追求和效果图完全一致的效果而单独对这里使用宋体),更合理的写法如下:
<style>
a:after{content:'\00BB';}
</style>
<a href="">更多</a>
\00BB— right double angle quote, unicode =»( » )
由于IE6/7不支持after伪类,退一步这样写也不错:
<a href="">更多»</a>
显示效果:
最好的例子就是wordpress编辑器左下角的路径处:
而面包屑导航处经常被写为的大于号也不是<而应是›根据wordpress后台的title写法:
<title>添加新文章 ‹ 99css — WordPress</title>
显示效果如下:
添加新文章 ‹ 99css — WordPress
把‹的l改成r就是右了
另看到aoao和怿飞在twitter上讨论空格,怿飞说:
测试发现空格还是用 \u0020 表示兼容性和语义最好
我也不是很认同,我的观点是:在html中使用 ,而在css中使用\20才是比较合理的做法:p
延伸阅读
20
一 10
[转载/翻译]优化浏览器渲染
ISD Webteam的大布同学(twitter:@tc_bryanzhang)牺牲了自己大量的xx时间翻译了Page Speed系列中的Optimize browser rendering,因其blog还在重新打造当中,所以偶这里先转载了,以下是翻译全文:
优化浏览器渲染
资源被下载到客户端后,浏览器仍需加载,解释,并渲染HTML、CSS和Javascript代码。只需利用现有浏览器的特性简单地编排你的代码和页面,就可以提升客户端的性能。
使用高效率的CSS选择器
概述
避免低效率的匹配大量元素的键选择器【key selectors】可以加快页面渲染。
详细信息
当浏览器解析HTML时首先构造一个内部文件树来代表所有显示的元素。然后浏览器根据标准的CSS级联、继承和排序规则,为元素指定匹配的各种样式。在Mozilla里的执行情况(可能在其他浏览器也是这样),CSS搜索引擎通过样式规则为每个元素找到匹配的样式。该引擎由右至左评估每个规则,从最右边的选择器开始(称为“键”【Key】),并通过移动每个选择器,直到找到一个匹配或丢弃的规则。(“选择器”是应用规则的文档元素。)
基于此原则,引擎要评估的规则越少越好。所以提高渲染性能的重要一步就是删除未使用的CSS。在此之后,对包含大量的元素和/或CSS规则的页面来说,优化规则本身的定义就能够提高性能。优化规则的关键在于尽可能具体定义规则,并避免不必要的重复,让样式引擎快速找到匹配的规则,而不用花费时间查找不适用的规则。
下列各类规则被认为是低效的:
后代选择器的规则
例如:
通配选择器作为键的规则
body * {...}
.hide-scrollbars * {...}
标签选择器作为键的规则
ul li a {...}
#footer h3 {...}
* html #atticPromo ul li a {...}
后代选择器是低效的,因为对于每个与键相匹配的元素,浏览器必须遍历DOM树,评估每一个祖先元素,直到找到一个匹配或到达根元素。键越不具体,需要进行评估的节点数量就越大。
子代选择器和相邻选择器的规则
例如:
通配选择器作为键的规则
body > * {...}
.hide-scrollbars > * {...}
标签选择器作为键的规则
ul > li > a {...}
#footer > h3 {...}
子代选择器和相邻选择器是低效的,因为对每个匹配的元素,浏览器必须评估另一个节点。这样导致规则中的每个子选择器加倍消耗。同样,键越不具体,需要进行评估的节点数量就越大。尽管如此,虽然同样效率低下,在性能方面相对后代选择器而言,它们仍然是可取的。
有多余修饰的规则
例如:
ul#top_blue_nav {...}
form#UserLogin {...}
ID选择是唯一的定义。加上标签或类的限制只增加了多余的、引起不必要评估的信息。
对非链接元素应用:hover伪选择器的规则
例如:
h3:hover {...}
.foo:hover {...}
#foo:hover {...}
div.faa:hover {...}
非链接元素上的:hover伪选择器在某些情况下*会使IE 7 和IE 8 变慢。当页面没有一个严格的doctype时,IE 7 和IE 8 将忽略除了链接外的任何元素的:hover。当页面有严格的doctype,在非链接元素上的:hover将导致性能下降。
*查看bug报告http://connect.microsoft.com/IE/feedback/ViewFeedback.aspx?FeedbackID=391387。
建议
避免通配选择器。
允许元素继承祖先的样式,或者使用一个类来给多个元素应用样式。
使您的规则尽可能具体。
尽量使用class和ID选择器而非标签选择器。
删除多余的修饰语。
这些修饰语是多余的:
ID选择器被class选择器和/或者标签选择器限制。
class选择器被标签选择器限制(当一个类只是用于一个标签,无论如何这都是一个很好的设计实践)。
避免使用后代选择器,特别是那些指定多余祖先的。
例如,这一个规则 body ul li a {...} 指定了一个多余的body选择器, 因为所有的元素都是body标签的后代。
使用class选择器代替后代选择器。
例如,如果您需要有序列表项和无序列表项有不同的两个样式,而不是使用两个规则:
ul li {color: blue;}
ol li {color: red;}
你可以将样式编码成两个类名并在规则中使用,例如:
.unordered-list-item {color: blue;}
.ordered-list-item {color: red;}
如果您必须使用后代选择器,尽量使用子代选择器,这最少只需评估一个额外的节点,而非中间直至祖先的所有节点。
在IE中避免对非链接元素应用:hover。
如果您对非链接元素应用:hover,请在IE7和IE8中测试并确保页面可用。如果您发现:hover导致性能问题,可以考虑条件性的为IE使用JavaScript onmouseover事件(只对IE写mouseover事件)。
附加资源
更多关于Mozilla里的高效CSS规则的细节,请看https://developer.mozilla.org/en/Writing_Efficient_CSS。
有关CSS的完整信息,请看Cascading Style Sheets Level 2 Revision 1 (CSS 2.1) Specification。有关CSS选择器的资料,请看Chapter 5。
避免CSS expressions
概述
CSS表达式会降低浏览器的渲染性能;用其他方案替换它们将会改善IE浏览器的渲染性能。
注意:本节最佳实践只适用于Internet Explorer 5到7,它们支持CSS表达式。Internet Explorer 8放弃使用CSS表达式,而其他浏览器是不支持的。
详细信息
作为一种动态改变文档属性来响应各种事件的的手段,Internet Explorer 5引入了CSS表达式或 “动态属性”。它们由在CSS声明中的CSS属性值里嵌入JavaScript表达式构成。在大多数情况下,它们用于以下目的:
模拟其他浏览器支持但IE浏览器尚未支持的标准CSS属性。
使用比编写全面JavaScript注入式样式更小巧,更便捷的方法,来提供动态样式和高级的事件处理。
不幸的是,CSS表达式对于性能的不良影响是相当大的,因为每当有事件触发,浏览器都要重新计算每个表达式,如一个窗口改变大小,鼠标移动等。CSS表达式的低性能表现是IE 8弃用它们的原因之一。如果你在网页里使用CSS表达式,应该尽一切努力来消除它们并且使用其他方法来达到同样的功能。
建议
尽可能使用标准的CSS属性。
IE 8已高度兼容标准CSS;IE 8只有在“兼容”模式才支持运行CSS表达式,而在“标准”模式下则不支持。如果你不需要向后兼容旧版本的IE,你应该转换成标准的CSS属性来替换所有对应的CSS表达式。如需CSS属性和支持它们的IE版本的完整列表,请参见MSDN的CSS属性索引。如果你确实需要支持所需CSS属性不可用的旧版本IE浏览器,请使用JavaScript来实现等效的功能。
使用JavaScript脚本样式。
如果你正在使用CSS表达式来实现动态样式,用纯JavaScript重写它们是很有意义的,因为这样既能提高IE性能,同时在其他浏览器获得相同效果的支持。在这个由MSDN动态属性页提供的例子里,下面的CSS表达式用于在浏览器里居中一个HTML块元素,并且该元素的尺寸可以在运行时改变,每次调整窗口大小都能重新定位在浏览器中心:
<div id="oDiv" style="background-color: #CFCFCF; position: absolute; left:expression(document.body.clientWidth/2-oDiv.offsetWidth/2); top:expression(document.body.clientHeight/2-oDiv.offsetHeight/2)">Example DIV</div>
下面是一个使用JavaScript和标准CSS的等价例子:
<style>
#oDiv { position: absolute; background-color: #CFCFCF;}
</style>
<script type="text/javascript">
// Check for browser support of event handling capability
if (window.addEventListener) {
window.addEventListener("load", centerDiv, false);
window.addEventListener("resize", centerDiv, false);
} else if (window.attachEvent) {
window.attachEvent("onload", centerDiv);
window.attachEvent("onresize", centerDiv);
} else {
window.onload = centerDiv;
window.resize = centerDiv;
}
function centerDiv() {
var myDiv = document.getElementById("oDiv");
var myBody = document.body;
var bodyWidth = myBody.offsetWidth;
//Needed for Firefox, which doesn't support offsetHeight
var bodyHeight;
if (myBody.scrollHeight)
bodyHeight = myBody.scrollHeight;
else bodyHeight = myBody.offsetHeight;
var divWidth = myDiv.offsetWidth;
if (myDiv.scrollHeight)
var divHeight = myDiv.scrollHeight;
else var divHeight = myDiv.offsetHeight;
myDiv.style.top = (bodyHeight - divHeight) / 2;
myDiv.style.left = (bodyWidth - divWidth) / 2;
}
</script>
如果您使用CSS表达式来模拟早期IE版本中不可用的CSS属性,你应该提供版本测试的javascript代码,为支持CSS的浏览器禁止CSS表达式。举例来说,max-width属性,这个属性在一定数量的像素范围内强制文本换行,在IE 7前是不支持的。下面的CSS表达式作为一种解决方法,为IE 5和6提供了这个功能:
p { width: expression( document.body.clientWidth > 600 ? "600px" : "auto" ); }
为不支持此属性的IE浏览器版本使用等价的JavaScript替换CSS表达式,可以使用类似于下面的内容:
<style>
p { max-width: 300px; }
</style>
<script type="text/javascript">
if ((navigator.appName == "Microsoft Internet Explorer") && (parseInt(navigator.appVersion) < 7))
window.attachEvent("onresize", setMaxWidth);
function setMaxWidth() {
var paragraphs = document.getElementsByTagName("p");
for ( var i = 0; i < paragraphs.length; i++ )
paragraphs[i].style.width = ( document.body.clientWidth > 300 ? "300px" : "auto" );
</script>
将样式放在页面头部
概述
将内联样式块和<link>元素从页面<body>移动到页面<head>中,这样能提高渲染性能。
详细信息
在HTML文件<body>中指定外部样式表和内联样式块可能对浏览器的渲染性能产生不利影响。浏览器阻塞渲染网页直到所有外部的样式表都已被下载。(用<style>标记指定的)内联样式块可能会导致reflows和页面跳动。因此,把外部样式表和内联样式块放在页面的<head>中是很重要的。通过确保样式表首先被下载和解析,可以让浏览器逐步渲染页面
建议
HTML 4.01规范(第12.3节)规定,始终把使用<link>标签的外部样式表放在<head>部分里。不要使用@import。还要确保您指定的样式有正确的顺序。
把<style>区块放在<head>部分里。
指定图片尺寸
概述
为页面中所有图片指定宽度和高度可以消除不必要的reflows和重新绘制页面【repaints】,使页面渲染速度更快。
详细信息
当浏览器勾画页面时,它需要能够流动的,如图片这样的可替换的元素。提供了图片尺寸,浏览器知道去环绕附近的不可替换元素,甚至可以在图片下载之前开始渲染页面。如果没有指定的图片尺寸,或者如果指定的尺寸不符合图片的实际尺寸,一旦图片下载,浏览器将需要reflows和重新绘制页面。为了防止reflows,在HTML的<img>标签中或在CSS中为所有图片指定宽度和高度。
建议
指定与图片本身相一致的尺寸
不要使用非图片原始尺寸来缩放图片。如果一个图片文件实际上的大小是60×60像素,不要在HTML或CSS里设置尺寸为30×30像素。如果图片需要较小的尺寸,在图像编辑软件中,设置成相一致的尺寸(详见优化图像。)
一定要指定图片或它的块级父元素的尺寸
一定要设置<img>元素本身,或它的块级父元素的尺寸。如果父元素不是块级元素,尺寸将被忽略。不要在一个非最近父元素的祖先元素上设置尺寸。
注:浏览器为了重新渲染部分或整个页面,重新计算页面元素位置和几何结构的进程叫做reflow
11
一 10
腾讯ISD招聘页面重构工程师
转发feeling哥的一则招聘:
招聘职位:页面重构工程师
招聘要求:
- 对符合web标准的网站重构有丰富经验,有成功案例;
- 精通结构化语言xhtml、xml与解释性语言css;
- 精通图像处理软件与网页编辑软件;
- 对业界最新的页面实现有浓厚的兴趣和深入的见解;
- 逻辑分析能力强,善于沟通,较强的学习能力;
- 熟悉对象模型与脚本语言,有前台开发经验者优先考虑;
招聘截至时间:2010年5月
如果你想应聘该职位,请发简历到csspeople@gmail.com,我们会尽快联系您。
10
一 10
在UlrtraEdit中配置Zen Coding
Zen Coding出来很久一段时间了,鬼哥更是在分享时潇洒的秀了一把,真是羡慕死人了。最近一直忙着搞需求,只有周末才有时间折腾一下,有点小郁闷~
- Aptana配置方法及详细介绍可以看前端观察翻译的Zen Coding: 一种快速编写HTML/CSS代码的方法,
配置起来有些麻烦,每个项目要导入一遍,另外虽然Aptana功能很强大,JQ/YUI等智能感知也很爽,不过有些慢 - Editplus配置方法见zen code for EditPlus,缺点是zen coding之前要先选中代码段,麻烦,另外在EP中的Consolas字体显示也很差劲
- Dreamwear配置方法见zen coding的dreamweaver插件安装教程,额,自从告别ASP后就没用过DW了
- Visual Studio 2008配置方法见[Tool]Zen-coding : Set of plugins for HTML and CSS hi-speed coding,这个很合我意,不过VS太过庞大,哪天系统崩溃时来个紧急需求,安装起来也要半天
- Vim的见在Vim里玩Zen Coding,Vim还木有用过,out了
Zen Coding中最吸引我的是html展开功能,一个轻量级的编辑器就够了,鉴于此选择了UltraEdit,用的是烈火汉化绿色版(绿色便携版没搞成功,貌似不支持),以下是配置方法:
- 下载UltraEdit Zen Coding.zip并解压Zen HTML UltraEdit.js至UltraEdit目录下的scripts目录中
- 按快捷键Ctrl+Shift+Z调出脚本窗口,点击添加按钮选择刚才解压的HTML UltraEdit.js并设置快捷键(我设置的Ctrl+Enter),按确定保存即可
接下来测试一下,新建文件,敲入以下语句:
div.mod.mod1>div.inner>div.hd+div.bd>ul>li*10>a
之后按下Ctrl+Enter,马上变成:
<div class="mod mod1"> <div class="inner"> <div class="hd"></div> <div class="bd"> <ul> <li><a href=""></a></li> <li><a href=""></a></li> <li><a href=""></a></li> <li><a href=""></a></li> <li><a href=""></a></li> <li><a href=""></a></li> <li><a href=""></a></li> <li><a href=""></a></li> <li><a href=""></a></li> <li><a href=""></a></li> </ul> </div> </div> </div>
大功搞成!
Zen Coding的html书写规则详见Zen HTML Elements