由来
从事软件行业一晃也5年有余,之间参与过若干个基于web的项目,所以javascript和Html基本已经相当熟悉,最近对于web前端开发比较关注,分析后发现CSS的确是自己的弱项,于是决定再加强下。就开始啃本书吧:《CSS权威指南》,此处以及以后文章都将以学习该书为基础展开。
以下是第一章:“CSS和文档” 学习笔记
概念区分
替换和非替换元素
CSS起作用主要依赖于元素,但并非所有的元素都以相同的方式创建。比如,图像和段落就不是同类元素,span和div也不相同,通常元素的表现形式有两类:替换和非替换。
-
- 替换元素(replaced element):
指用来替换元素内容的部分并非由文档内容自己标示。比如img元素,img没有具体内容,它的具体靠src属性指定的一个图像来填充。再比如:<input /> type="text" 的是,这是一个文本输入框,换一个其他的属性(button)时候,浏览器显示就不一样。(X)HTML中的<img>、<input>、<textarea>、<select>、<object>都是替换元素,这些元素都没有实际的内容。
-
- 非替换元素(nonreplaced element):
大多数(X)HTML元素都是非替换元素,其内容由浏览器在元素本身生成的框中显示。比如<span>css base</span>就是一个非替换的元素。
块元素和行内元素
-
- 块元素:
块元素生成一个元素框,默认情况下(没有css干预下),它会填充其父元素的内容区,旁边不能有其他元素。比较熟悉的有p和div。可以把块元素div想象成一个个box,或者如果你玩过剪贴文载的话,那就更加容易理解了。我们先把需要的文章从各种报纸、杂志剪下来。每块剪下来的内容就是一个block。然后我们把这些块按照自己的排版意图,用胶水重新贴到一张空白的新纸上。这样就形成了你自己独特的文摘快报了。
-
- 行内元素:
行内元素在一个文本行内生成元素框,而不会打断这行文本。最好的例子就是XHTML中的a元素。这些元素不会在它本身之前或者之后生成“分隔符”,所以可以出现在另一个元素内容中,而不会破坏其显示。
当然在实际的使用过程中往往会用css属性来其作用:display。这个属性是使用,会在后期学习奉上。
关于link
一般一个html页面要引用独立文件的css样式,都会用到link标签,比如:
<link rel=”stylesheet” type=”text/css” href=”sheet1.css” media=”all”>
在使用过程中需要注意几点:
-
- Link必须放在head元素中,不能放在其他元素内部<如title>。
- Css文件中不能包含XHTML或任何其他标记语言。
- 外部引用css文件不一定非得有个扩展名,但是基于对旧版本的浏览器的支持,建议写明.css结尾。
另外在使用过程中,我们也很少接触一个link标签属性:title(获选样式表中使用)。比如:
<link rel=”stylesheet” type=”text/css” href=”sheet1.css” title=”default”> <link rel=”stylesheet” type=”text/css” href=”sheet1.css” title=”big-text”>
很多浏览器支持用户选择样式,通过添加title用户可以基于浏览器进行样式的切换,当然IE目前还是不支持,这个功能也用的比较少。