一、position定位
1.position定位属性:检索对象的定位方式
语法:
position: static/absolute/relative/fixed/sticky;
取值:
1.1、static: 默认值,无特殊定位,对象遵循HTML原则;
1.2、absolute: 绝对定位,将对象从文档流中脱离出来,使用lef/right/top/bottom等属性相对其最接近的一个并有定位设置的父元素进行绝对定位;如果不存在这样的父对象,则依据根元素(html)《浏览器》进行定位,而其层叠通过z-index属性定义。
1.3、relative :相对定位,该对象的文档流位置不动,将依据right, top, left, bottom (相对定位)等属性在正常文档流中偏移位置;其层叠通过z-index属性定义。
1.4、fixed: 固定定位,对象定位遵从绝对定位方式(absolute) ,但是定位元素的参考对象是视口(准确的说是视口产生的包含块,此包含块的尺寸和左上角均与视口一致,于是当我们拖动滚动条的时候,fixed定位的元素会有固定效果。),而不是距离它最近的采用定位的元素。如果固定定位的尺寸是百分比形式,它的参考尺寸也是视口的尺寸。所以fixed和absolute的区别主要在于参考对象不同。(IE6浏览器不支持此定位) ;
1.5、sticky: 粘性定位,粘性定位并不会脱离文档流,top、bottom、left和right属性分别设置元素粘性定位的临界值,基本上,可以看出是position:relative和position:fixed的结合体——当元素在屏幕内,表现为relative,就要滚出显示器屏幕的时候,表现为fixed。(position:sticky要想生效,top属性或则left属性(看滚动方向)是必须要有明确的计算值的,否则fixed的表现不会出现。)
2、定位元素的层级属性
z-index:auto | number 检索或设置对象的层叠顺序。
auto:默认值,遵从其父对象
number:无单位的整数值。可为负数
没有设置z-index时,最后写的对象优先显示在上层,设置后,数值越大,层越靠上;
说明:
1)较大数值的对象会覆盖在较小数值的对象之.上。如两个绝对定位对象的此属性具有同样的
number值,那么将依据它们在HTML文档中声明的顺序层叠。
注意:
页面根元素会形成层叠上下文,其他层叠上下文的产生由z-index值不为auto的定位元素(positioned 非static)。层叠上下文不一定与包含块有关。在新版本的CSS中,其他的一些属性也会产生层叠上下文,比如 ‘opacity’。
同一层叠上下文中,层叠级别大的显示在上,层叠级别小的显示在下,相同层叠级别时,遵循后来居上的原则,即其在HTML文档中的顺序。
不同层叠上下文中,元素呈现顺序以父级层叠上下文的层叠级别来决定呈现的先后顺序,与自身的层叠级别无关。
例如:定位元素A(z-index:100)里面有定位元素A1(z-index:300),而定位元素B和元素A兄弟关系(z-index:200)。你会发现无论A1的z-index是多大,也会被z-index是200的B所覆盖,因为A的z-index只有100。
二、包含块的概念和作用
包含块(Containing Block)是视觉格式化模型的一个重要概念,它与框模型类似,也可以理解为一个矩形,而这个矩形的作用是为它里面包含的元素提供一个参考,元素的尺寸和位置的计算往往是由该元素所在的包含块决定的。
包含块简单说就是定位参考框,或者定位坐标坐标系,元素一旦定义了定位显示(相对、绝对、固定)都具有包含块性质,它所包含的定位元素都将以该包含块为坐标系进行定位和调整。
定义元素为包含块:给绝对定位元素的父元素添加声明position; relative;
如果我们的父素设置了position:absolute;那么子元素也会相对父元素来定义自己的位置。
绝对和相对定位的区别
1、参照物不同,绝对定位(absolute) 的参照物是包含块(父级) ,相对定位的参照物是元素本身位置;
2、绝对定位将对象从文档流中拖离出来因此不占据空间,相对定位不破坏正常的文档流顺序无论是否进行移动,元素仍然占据原来的空间。
三、锚点
命名锚点链接的应用定义:
是网页制作中超级链接的一种,又叫命名锚记。命名锚记像一个迅速定位器一样是一种页面内的超级链接,运用相当普遍。
命名锚点的作用:在同一页面内的不同位置进行跳转。
制作锚标记:
1)给元素定义命名锚记名
语法: <标记id="命名锚记名"> < /标记>
2)命名miaodian锚记连接
语法:<a href="#命名锚记名"></a>
四、透明度
设置元素的不透明度
语法:(常规浏览器)
opacity: value;
value取值:0-1(0.1,0.2,0.3....0.9,1)
0为透明,1为不透明,0.5为半透明
IE浏览器写法:
filter:alpha(opacity=value);
vaue取值范围:0-100
五、Flash和滚动字幕
由于flash已经被抛弃很久了,所以了解一下就行。
1、插入flash
1)语法:
<object width= "value" height="value" >
<param name=”movie" value="flash路径及全称" />或者
<embed width= "value" height= "value" src="flash路径及全称" > </embed>
</object>
2)将flash背景设置为透明
<embed wmode= "transparent" />
给<embed>标记添加属性: wmode=”transparent"
flash源文件格式.fla, 导出影片为.swf, 创建播放器格式为.exe gif格式: .gif
3) IE中不显 示flash,可做如下操作:
A.下载安装flash player; B.打开IE浏览器,选择I具菜单--Internet选项---安全---低。
2、滚动字幕的应用:
<marquee behavior (行为) = "scroll(滚动)/alternate (晃动) "direction (方向) = "up(从下向上)/down (从上向下) /left (从右向左) /right (从左向右)"
scrollamount (滚动速度) = "value" height= "value(上下滚动范围)"width=””(左右滚动范围)>
内容
</marquee>
拓展:
创建包含另外一个文档的内联框架(即行内框架)
< iframe src="http://www.baidu.com" scrolling=”no" frameborder="0" > </iframe>
src url 规定在iframe中显示的文档的URL。
scrolling yes或者no 规定是否在iframe中显示滚动条。
frameborder 0或者1 规定 是否显示框架的边框。