CSS技巧 – 设计之家 //www.laura-marie.com 传播先进设计理念 推动原创设计发展 Sun, 11 Nov 2007 02:29:00 +0000 zh-Hans hourly 1 https://wordpress.org/?v=6.9.4 css技巧之PDF、ZIP、DOC链接的标注 //www.laura-marie.com/12745.html //www.laura-marie.com/12745.html#respond Sun, 11 Nov 2007 02:29:00 +0000

原文:http://www.maratz.com/blog/archives/2005/01/13/pdf-links-labeling/
翻译:http://www.176so.com/past/2007/3/17/pdf_links_labeling/

css技巧之PDF、ZIP、DOC链接的标注

有时候我们希望能明确的用小图标来标明我们的超链接的类型。是一个zip文档还是一个pdf文件。这样访问者就知道他所要点击的这个链接是下载而不是打开另一个页面了。如果所有的人都使用IE7或者FF的话。我们完全可以使用[att$=val]属性选择器,寻找以特定值(比如.zip和.doc)结尾的属性。

a[href$=”.pdf”] { padding-right: 19px; background: url(pdf.gif) no-repeat 100% .5em; }
a[href$=”.zip”] { padding-right: 17px; background: url(zip.gif) no-repeat 100% .5em; }

不幸的是IE6以下浏览器不支持属性选择器。好在,可以通过在每个元素中添加类,使用JavaScript和DOM实现相似的效果。

下面给出了一个解决办法:

function fileLinks() {
    var fileLink;
    if (document.getElementsByTagName(‘a’)) {
        for (var i = 0; (fileLink = document.getElementsByTagName(‘a’)[i]); i++) {
            if (fileLink.href.indexOf(‘.pdf’) != -1) {
                fileLink.setAttribute(‘target’, ‘_blank’);
                fileLink.className = ‘pdfLink’;
            }
            if (fileLink.href.indexOf(‘.doc’) != -1) {
                fileLink.setAttribute(‘target’, ‘_blank’);
                fileLink.className = ‘docLink’;
            }
            if (fileLink.href.indexOf(‘.zip’) != -1) {
                fileLink.setAttribute(‘target’, ‘_blank’);
                fileLink.className = ‘zipLink’;
            }
        }
    }
}
window.onload = function() {
    fileLinks();
}

当然,你需要在你的css文件中,增加这几个css类:

.pdfLink { padding-right: 19px; background: url(pdf.gif) no-repeat 100% .5em; }
.docLink { padding-right: 19px; background: url(doc.gif) no-repeat 100% .5em; }
.zipLink { padding-right: 17px; background: url(zip.gif) no-repeat 100% .5em; }

最后一点建议,你的小图标不要过分醒目,这会分散浏览者的注意力。

 

]]>
//www.laura-marie.com/12745.html/feed 0
14个常见的CSS技巧及常见问题 //www.laura-marie.com/12585.html //www.laura-marie.com/12585.html#respond Thu, 25 Oct 2007 18:26:00 +0000 1、善用css缩写可以减少页面文件大小,提高下载速度,同时使代码简洁可读。
如:

div{
    border-top:1px solid #cccccc;
    border-left:1px solid #cccccc;
    border-right:1px soli #cccccc;
    border-bottom:1px solid #cccccc;
}

可以写为

p{border:1px solid #cccccc}

再如:

div{
    margin-top:10px;
    margin-right:20px;
    margin-bottom:30px;
    margin-left:40px;
}

可以改写为:

/*注意上、右、下、左的书写顺序*/
div{margin:10px 20px 30px 40px}
/*注意,数值与单位不能有空格,每个值之间用空格隔开*/

(详细请参考:css2参考手册、常用css缩写总结)

2、可以同时为一个html元素的class属性设定多个规则(多重class定义)。
通常我们写法为:<p class=”a”></p>
实际上我们可以为p元素指定多个规则,如:

CSS:
.a{…}
.b{….}
HTML:
<p class=”a b”>该元素同时包括a和b中设定的样式</p>

注意:多个规则之间用空格分开。

3、明确定义单位,除非值为0
忘记定义尺寸是css初学者新手普遍存在的问题。在html我们可以写width=”100”,但在css中应该给出一个准确的单位。如:width:100px;height:50px;font-size:9pt ,0值除外,因为不论对于任何单位。0值的大小都是相等的。

注意:不要在数值和单位之间加空格。

4、区分大小写
在xhtml中,css定义的元素名称是区分大小写的,class和id的值在html和xhtml中也是区分大小写的,所以为了避免错误,推荐一律使用小写。
如#aaa,与#AAA是不同的,在xhtml中,p和P也是不同的.他们之间不会覆盖。
如果在css中定义了#aaa,在html元素中使用AAA来应用将不能得到#aaa中定义的样式。
示例代码:

CSS:
#aaa{border:1px solid #ccc}  
HTML:
<div id=”AAA”>显示不出来1个像素的边线</div>

5、CSS的最近优先原则
如果对一个元素定义了多次样式,则以最近的一级优先,最近一级的样式将覆盖其他的样式定义。
如:

CSS:
p{color:red}
.blue{color:blue}
.yellow{color:yellow}
HTML:
<p>此处显示为红色</p>
<p class=”blue”>此处显示为蓝色</p>
<p class=”blue” style=”color:green”>此处显示为绿色</p>
<p class=”blue yellow”>此处显示为黄色</p>

注意:
(1)注意样式的几个优先顺序(优先级由上至下递减):
–元素style设定
–head区<style></style>中的设定
–外部引用css文件
(2)优先级不是按访问顺序来设定的,而是又css中的声明顺序来设定的。
如上例中<p class=”yellow blue”>此处显示为黄色</p>也显示为黄色,因为在css定义中.yellow在.blue的后面。

6、使用子选择器减少id和class的定义
例如:

#contain{..}
#contain_ul{…}
.contail_li{…}
<div id=”contain”>
    <ul id=”contain_ul”>
        <li class=”contain_li”></li>
        <li class=”contain_li”></li>
    </ul>
</div>

可以更改为:

#contain{..}
#contain ul{…}
.contain ul li{…}
<div id=”contain”>
<ul>
    <li></li>
    <li></li>
</ul>
</div>

7、不要给背景图片路径加引号
将background:url(“xxx.gif”)改为background:url(xxx.gif)
因为对于部分浏览器加引号反而会引起错误。

8、背景图片的路径是相对与当前css页面的路径。

例如:
有如下目录结构
|–images
   |–xxx.gif
|–css
   |–xx.css
|–index.html
代码内容
index.html引用xx.css文件。<link rel=”stylesheet” href=”css/xx.css” />
xx.css要引用xxx.gif图片其写法为:background:url(../images/xxx.gif)

9、使用组选择器为不同元素应用相同的样式
如h1,h2,h3,div{font-size:16px;font-weight:bold}
则h1,h2,h3,div元素的样式都为字体16像素,字体粗体

10、书写正确的链接样式
当用css定义链接的各种状态时,一定要注意其书写顺序,即::link :visited :hover :active
如果不按照该顺序书写可能无法达到自己希望的效果。为了记忆该顺序我们抽取每个单词的首字母:L V H A,你可以通过记忆LoVe,Hate,两个单词来记住其顺序。

11、禁止内容换行与强制内容换行
在表格或层中我们可能希望内容不换行或强制换行,我们可以通过一些css属性来达到这些要求。
禁止换行:white-space:nowrap
强制换行:word-wrap: break-word; word-break: normal;

12、区别relative和absolute
Absolute,CSS中的写法是:position:absolute; 他的意思是绝对定位,他是参照浏览器的左上角,配合TOP、RIGHT、BOTTOM、LEFT(下面简称TRBL)进行定位,在没有设定TRBL,默认依据父级的做标原始点为原始点。如果设定TRBL并且父级没有设定position属性,那么当前的absolute则以浏览器左上角为原始点进行定位,位置将由TRBL决定。

Relative,CSS中的写法是:position:relative;  他的意思是绝对相对定位,他是参照父级的原始点为原始点,无父级则以BODY的原始点为原始点,配合TRBL进行定位,当父级内有padding等CSS属性时,当前级的原始点则参照父级内容区的原始点进行定位。

13、区别div和span
div是一个块级元素,可以包含段落,表格等内容,用于放置不同的内容。一般我们在网页通过div来布局定位网页中的每个区块。
span是一个内联元素,没有实际意义,它的存在纯粹是为了应用样式,给一段内容加上<span></span>标记可以通过在span上定义样式来设定其内容的样式。

14、区别display和visibility
display:none和visibility:hidden都可以隐藏一个元素
但visibility:hidden只是隐藏了元素的内容,但其使用的位置空间仍然被保留。
而display:none则相当把元素从页面中去除,其占用位置也将被删除。

]]>
//www.laura-marie.com/12585.html/feed 0
CSS技巧:段正淳的css笔记 //www.laura-marie.com/12572.html //www.laura-marie.com/12572.html#respond Wed, 24 Oct 2007 18:12:00 +0000

淘宝首页上的一个小技巧。

类目之间的横竖线

从很久很久以前开始,类目间的竖线无非都只有三种。

  1. 背景图
    在a标签设置一个padding 用宽1px高不等的背景图来position到右侧。
    缺点:最后一个还是要用class来隐藏掉背景。
  2. 符号
    在每个a标签之间用”|”符号来填充。
    缺点:html文件变大,文件维护变得很麻烦,而且在html中毫无意义。
  3. a标签右侧的boder。
    同背景图一样,只不过使用border-right来代替。缺点也同上。

看到这里,可能已经有人打开淘宝首页用firebug查看源码来看是怎么做了。

其实现有是利用ul的overflow:hidden 再将li的margin-left:-1px的做法做出来的。这样的做法就可以同时避免以上的缺点了。
为什么之前都没有那么做的,寡人也不知道了。难道寡人是第一个发现这样的做法?
不管是谁先此之前利用了这样的方法实现类目间竖线。
不过在淘宝首页上线后不久就有同行的网站在首页改版中也用了这样的方法。
那个网站不看也罢。class实在是写的有点多。加载html会变得多得多。
反正一个首页需要加载1.17m的网页我的大脑会自动屏蔽。

圆角的做法.

为了这个圆角,前段开发们付出的努力是在是太多了.又要考虑http连接数,又要考虑css与html的代码量与语义.
贴出的是最近考虑替换现有圆角做法的方案,可能还有许多未考虑的状况.但是大体的编写方式便是如下.
好处是便于维护,只有一个图片.还可以某种程度上的任意缩放.缺点是多了无意义的html代码.

css:
.c,.c i,.c i i,.c b,.c b b,.c p{
background-image:url(//images.sj33.cn/uploads/allimg/200710/20071025021934233.png);/*背景图片*/
background-repeat:no-repeat;
}
.c{
width:200px;/*临时定的宽度*/
background-position:0 -4px;
}
.c i{
display:block;
height:4px;
}
.c i i{
margin:0 0 0 4px;
background-position:right 0;
}
.c b{
display:block;
height:4px;
background-position:0 bottom;
}
.c b b{
margin:0 0 0 4px;
background-position:right bottom;
}
.c p{
margin:0 0 0 4px;
padding:0 4px 0 0;
background-position:right -4px;
}

html:
< P class=”c”>
< i>< i>< /i>< /i>
< p>
按钮按钮按钮按钮按钮按钮
按按按按按钮按钮按钮按钮按钮按钮按钮按钮按钮按钮按钮按钮
< /p>
< b>< b>< /b>< /b>
< /P>

table的全局定义

caption这个标签在firefox下会有左边有1px空隙的bug,很讨厌.能想到的简单的方法只有-1px的margin了.

css:
table{
border-collapse:collapse;
}
table caption,table td,table th{
border:1px solid #a2bbdd;/*边框颜色*/
background:#c3d9ff;/*背景颜色*/
}
table caption{
text-align:left;
border-bottom:none;
margin-left:-1px;
}

html:
< table>
< caption>表格标题< /caption>
< tr>
< th>标题< /th>
< th>标题< /th>
< th>标题< /th>
< th>标题< /th>
< /tr>
< tr>
< td> 内容< /td>
< td> 内容< /td>
< td> 内容< /td>
< td> 内容< /td>
< /tr>
< /table>

需要正视的二个标签

  1. acronym这个标签用来解释名词很爽,但是用得太少.(我也一直想用来着,所以记下了.)
    css:
    acronym{cursor:help}
    html:
    < acronym title=”段正淳又是金庸笔下一个十分奇特的人物。他奇特在到处留情,情人极多,见一个爱一个,而又绝不是徒然风流薄幸,当他是单独对着一个情人的时候,他真是真心真意爱这个情人的,只好说这个人的感情特别丰富,别无其他解释。” >文字< /acronym>
  2. ins这个标签忘记是在哪个网站上看到过用来在h2里显示更多的链接,后来查了书,大家都觉得有点欠妥,有点争议.
    css:
    还未写入css组件…欠奉上了
    html:
    < h2>标题< ins>< a xhref=”http://ued.taobao.com/blog/#” mce_href=”http://ued.taobao.com/blog/#” >更多>>< /a>< /ins>< /h2>

标题右侧“更多”的实现

曾经做上图所示的效果,会使用到position来相对定位到h2标签的右侧.这样的做法,代码确实会多好几行. 其实可以用个笨一点的办法来实现的:

譬如html代码如下:

< h2>< a h ref=”#” >标题< /a> < span>更多…< /span> < /h2>

使用potsition的css差不多如下:

h2{
position:relative;
height:20px;
}
span{
position:absolute;
right:0;
top:0;
display:block;
height:20px;
}

这样才能实现更多在右侧.其实真的还可以更简单:

h2{
height:20px;
}
span{
float:right;
display:block;
margin:-10px 0 0 0;
height:20px;
}

其实只是利用了margin-top 的负数来实现,因为默认的float会换行到h2标签下面去,所以让它自个跳上去。大致代码就是如此了,是不是很简单?我说很简单嘛!由于很简单,所以就不放出单独的测试页面了.

ps:我说咱们啥时候也得搞个和蓝色理想一样的编辑器吧…

淘宝的css属性顺序书写规范

以前部门的同事们,每个人都有一套书写的规范,导致看对方的css代码非常吃力,所以就推行了一套书写标准 ,或许对您也有帮助。

*{
/*显示属性*/
display
position
float
clear
cursor

/*盒模型*/
margin
padding
width
height

/*排版*/
vertical-align
white-space
text-decoration
text-align

/*文字*/
color
font
content

/*边框背景 为什么要把 boder和background放在最后的原因是修改的频率会较之前的频繁,放在最后查看起来方便,哈哈。*/
border
background
}

说到底其实属性的书写顺序规范就是:神仙?妖怪? – 身材怎么样!- 服装类型(比基尼?棉袄?) – 服装款式(黑色?白色?纽扣?拉链?) – 用了啥化妆品和发型.
这个书写标准小部分并不是浏览器厂商推行的书写规范,所以可能被广大标准推广者所不认同 。但这些个都是弟兄几个实践出来认为最符合现有淘宝环境的。

css代码的简写

css缩写的语法,对新手有一定帮助,老鸟就不用看了.

  1. 0px不需要单位,直接:margin:0
  2. 盒模型的缩写,语法是margin:上 右 下 左;.甚至可以简写成margin:上 (右左) 下,当然右左的值应该是一样的
  3. css属性的最后一项”;”号省略。(不建议 ^_^)
  4. 字体宽度normal用400代替,bold用700代替。
  5. 16进制的色彩值,如果每两位的值相同,可以缩写一半,例如:#000000可以缩写为#000;#0044DD可以缩写为#04D;
  6. border边框的缩写,语法是border:width style color,类似boder:1px solid red;
  7. 背景background的缩写,语法是color image repeat attachment position.类似:background:#f00 url(background.gif) no-repeat fixed 0 0( 为什么我从不写fixed呢?)
  8. 字体的缩写,类似font:italic small-caps bold 1em/140% “SimSun”,sans-serif,可以省略到最简单font:12px “SimSun”.
  9. list的属性缩写,语法list-style:square inside url(image.gif) ,不过一般咱们都不用.
  10. 想凑10条, 还真难.就把删除无用换行符和空格算一个吧

]]>
//www.laura-marie.com/12572.html/feed 0