关于界面的价值观与方法论
891011121314151617

我最近的CSS习惯

14December2008

之前有要求我多写点CSS方面的,那就写吧。因为习惯其实是会变的,所以只能写“最近”的。这些习惯都跟技术无关,如果不遵守,也不会出错。但是我觉得良好的习惯会体现一个人的素质。

1. class_name方式写类名。以前喜欢用class-name写,不过好像两样也没什么差别。但我比较反对用className写类名,因为始终对浏览器大小写敏感的问题抱有怀疑态度。但是id我会写成驼峰式,理由见下一条。

2.样式都用class而不用id。有三个理由,一,id不可以重复,所以用class的话,可以肆无忌惮的用无数次。二,id的优先级太高,若是写了一个#page_content a {color:#f60} ,那你完蛋了,里面要改链接颜色,都必须加上#page_content才能越过这个优先级。三,id专门留给JS用,这样才符合表现与行为分离的原则。所以id我用驼峰式,也是为了体现这一点。

3.margin和padding,尽量省略最后一个值。比如margin: 20px 10px 5px 10px; ,左右值是一样的,就应该省略掉最后一个值,写成margin: 20px 10px 5px; 这样到时候要改左右间距,改一个就好,免得改漏了。其实这个问题虽然很细小,但是可以看得出对margin四个值省略规则的熟练程度。

4.按标准写CSS,再针对特定浏览器作hack。比如,通常我们会遇到如下的写法:

.side_col {
    float:left;
    display: inline;
    margin-left: 20px;
}

而我的写法会是:

.side_col {
    float: left;
    margin-left: 20px;
}
*   .side_col {
    _display:inline;  /*hacked for IE 6*/
}

看明白了么?不应该把hack混在一起,也不应该用一种侥幸的心态,觉得float:leftdisplay:inline写在一起没事。嗯,它们俩确实没事儿,但是其他的hack就不一定了。而且这里写display:inline纯粹就是为了解决IE6的bug,所以前面加上下划线,以明确的表达你的目的。

另外不要以为凡是hack都是为IE准备的。其实有些hack是针对其他浏览器的,比如FF。这就要求你对CSS标准的熟练掌握,能够自信的判断哪些渲染是遵守标准,哪些违反标准的。

此外,我喜欢在hack前面加上星号,其实这纯粹是个人习惯了。可能过段时间我就不这么用了,呵呵。

5. 记得加空格。.class_name { property: value; } 。我个人觉得合理的空格是优秀代码的一个指标。按英文的习惯,标点后面都应该带空格(如果你写This is a pen.That’s a pencil.句点后面不加空格, word里面会有错误提示)。所以既然CSS是外国人发明的,应该按他们的格式来写。类似的,在JS里var a = b + c;里面的空格也应该都要加。

6.适当的层叠(Cascading)或缩进以定义CSS的“作用域”。啥叫“CSS的作用域”?其实并不是所有的样式都在所有的地方使用。有的样式只用在某一块里面,比如“导航栏”里的“搜索框”,可能应该写成:

.nav .search {}

而有时候用层叠会增加代码优先级,所以也可以用缩进来“象征性的”体现作用域。像这样:

.login_box {}
   .forgot_pwd{}

缩进,是为了表示它们对应的标签具有父子关系。但这样只能起一个提醒的作用。

D2的背后

1December2008

D2总算结束了。就讲一下它背后的一些事情吧。

答应这件事情是在8月。原本以为只是一个小小的聚会,结果雪球越滚越大。头疼的是,9月爆发金融危机,很难再铺张的请到款。开始前两天,我在公司里群发邮件,招募了十来个同事来义务帮忙。结果之前烦恼的事情一下子迎刃而解。我大概是生平第一次组建了这样一个完美的团队。这当然不是因为我本人的能力,而是土豆网给了一个挑不完的精英人才市场。

周四晚上把活动分为签到、设备、主持和现场、后勤四个部分,周五上午花了30分钟确定好各小组的任务和责任。周六所有人准时各就各位。就这么OK了。没有突发事件,没有意外情况。我不在乎活动本身是否大受好评,组织上没有任何问题,这足以让所有辛苦的同学们感到成就和开心了。

不过也有一些心得:
1. 总负责人不要给自己安排任何具体任务。把事前能想到的所有事情都分配给具体的人,你需要处理的是事前想不到的事情。
2. 好的团队成员只需要满足两点:绝对负责和主动优化。
3. 其实很多时候,皇帝都比太监更急,只要你确认他知道自己是皇帝。
4. leader和member的关系并不是上下级关系,只是分工不同的合作关系。
5. 如果你会紧张,就提前两个小时开始紧张。不是说到后来就不会紧张,而是到后来你自己就习惯了在紧张的情绪中自如的呼吸,这样至少看不大出来了。
6. 所谓“成功”,就是辛苦之后很开心。别的都不重要。

配色字典(二)

23November2008