css中有关于定位的一个属性position。
在w3cschool中,position的介绍如下:
值 | 描述 |
---|---|
absolute |
生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。 元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。 |
fixed |
生成绝对定位的元素,相对于浏览器窗口进行定位。 元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。 |
relative |
生成相对定位的元素,相对于其正常位置进行定位。 因此,"left:20" 会向元素的 LEFT 位置添加 20 像素。 |
static | 默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。 |
inherit | 规定应该从父元素继承 position 属性的值。 |
公司有个老项目,使用百度的webuploader作为上传组件,按照例子编写。
在页面高度不是很大的情况下,很正常,但是当页面高度比较高的时候(页面需要scroll)的时候,发现点击总是没有任何的反应。
摸索了半天,发现响应事件的组件(不可见)的位置属性是:abosulute。
又看了下baidu官方的例子,如下图:
问题是,webuploader计算的位置并不准确(由于某些设置),所以只能手动修改了:
[id^="rt_rt_"]{ position: relative !important; display:inherit !important; width:100px!important; height:20px!important; margin-top: -20px; }