位置: 编程技术 - 正文

推荐深入理解css中的position定位和z-index属性(深入理解typescript 豆瓣)

编辑:rootadmin
作者:Cutsin 原文地址: 注:本文仅供交流使用,如有不当之处欢迎批评指正,但请注明详由,谢谢! 由于平时不太用到,所以过去写css的时候对于position属性的absolute、relative值理解比较模糊,对于z-index的层叠更是摸不着头脑,除了理解的因素外,各个浏览器的不同解析结果也是一个大问题。今天仔细阅读了一下css文档,总算是对盒模型的浮动、定位有了比较深刻的理解。 我们在实践中很有可能遇到这样的问题: 1、做一个横向导航,然后鼠标经过之后出现下拉菜单,那么这个下拉菜单的位置控制就是一个关键; 2、我们想在一个正常的页面布局中放入几个浮在页面上的气泡提示,这时既不想让气泡提示破坏正常的文档布局,又不想气泡提示的定位在不同的浏览器中到处乱飘。 3、当我们在一句正常的文本中插入一个小图标的话,一般会使用<img />标签,而这时它的垂直居中问题又是让人困惑,无论你使用html属性absmiddle、或是使用css属性vertical-align、抑或是使用父对象的heigh + line-height,在不同的浏览器中总会看起来不同。 嗯,上面几个问题你是否也遇到过呢?如果你至今还没有一个很好的解决办法,不妨继续阅读此文,或许能对你有所帮助:) 我们先看一下position属性的几个取值定义:position: static、absolute、relativestatic : 默认值。如果没有指定position属性,支持position属性的html对象都是默认为static,可以这么理解:把html页面看作一个文档流,源代码中各个标签的先后位置就是它们所对应的对象的呈现次序,所有取值为static的对象都按照你所编写的html标签的顺序依次呈现。如下图所示,这是一个常见的指定了float:left;的横向导航:relative: 相对定位。这个属性值保持对象所在文档流中的位置,也就是说它具有和static相同的呈现方式,它同样占有在文档流中的固定位置,后面的对象不会侵占或覆盖;与static属性值不同的是,设置了relative的对象,可以通过top, left, right, bottom属性设定自己的新显示位置,这4个属性的取值是相对于文档流的前一个对象的,你可以自由设置这4个属性偏移到新的位置而不对文档流中的其他对象产生任何影响,原来的页面呈现仍然会我行我素:absolute: 绝对定位。和relative不同的是,这个属性值会将当前对象拖出文档流,后面的对象会占有原来的位置,也就是说,当前对象的呈现是独立显示的,但是它的位置在指定top, left, right, bottom任一属性之前仍是有继承性的,这时的4个属性的取值是相对于浏览器的,和文档流无关了。如果把示例中的B区域设定为absolute而不指定4个位置属性,通过设定margin来改变它的相对位置,用这个方法可以解决前面提到的问题2。提示a: 苏昱的css2.0手册中提到relative和absolute定位的滚动条区别不是绝对的,至少在firefox、opera和safari中滚动条该出现还是会出现。提示b: 属性值为absolute对象的z-index属性可以设置层叠显示的次序,它是直接有效的;而属性值为relative对象的z-index属性在设置时要小心,把当前对象的z-index设置为-1是不行的,在firefox中它会无法显示(注意,不是说浏览器有误,而是指如果父对象是根元素body,那么z-index是无效的,任何z-index设置都不会显示在根元素之后,除了IE的解析bug,感谢#提示),必须设置为0以上,我们如果想让别的对象挡住它,只有将其他对象也设置position为relative,并将z-index属性取一个比它大的值即可。上面的表述不知道也许不是很清晰,具体的理解还是要自己亲自动手操作一下。这样看来,前面的问题就有解了,问题3我们可以根据设计的要求将其设置为相对或绝对定位;问题1的解决方法也有很多,个人推荐使用有语义的dl, dt, dd来实现,而且这个方法在不同浏览器中的表现基本相同(已在ie, firefox, opera, safari中测试),仅在top的属性上有几像素的差异,由于时间关系我只能给出自己测试时的代码以供参考:body { color:#fff; font-size:px; } ul li { float:left; height:px; background-color:#CC; margin:0 px; padding:0; border:1px solid #c; width:px; } ul li div { border:1px solid #f; background-color:#; width:px; height:px; position:absolute; margin-top:px; margin-left:-1px; *margin-left:-px; } ul li dl, ul li dl dt, ul li dl dd { margin:0; padding:0; } ul li dl dd { border:1px solid #f; background-color:#; width:px; height:px; position:absolute; margin-top:px; *margin-top:px; margin-left:-1px; } 标题 - #text 下拉菜单 - div 列表b 列表c 标题 - dt 下拉菜单 - dd [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]补充一个例子,请在IE和非IE浏览器中对比观看: 一段文本一段文本一段文本一段文本一段文本一段文本一段文本 另一段文本另一段文本另一段文本

推荐整理分享推荐深入理解css中的position定位和z-index属性(深入理解typescript 豆瓣),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:深入解析csspdf百度网盘,深入解析css电子书,深入浅出css,深入解析css电子书,深入解析csspdf,深入理解javascript pdf,深入解析css电子书,深入解析csspdf百度网盘,内容如对您有帮助,希望把文章链接给更多的朋友!

推荐深入理解css中的position定位和z-index属性(深入理解typescript 豆瓣)

第三段不同的文本第三段不同的文本

第四段指定了block的文本

第四段指定了block的文本 第四段指定了block的文本 第四段指定了block的文本 第四段指定了block的文本 [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]从这个例子可以看出,IE将一个块元素绝对定位时,如果父元素是一个块级元素,那么拖出文档流之后它仍会继承原来所在位置的坐标; 而非IE浏览器的做法是:拖出文档流之后,直接定位到父元素所在的坐标。

不错的个你未必知道的CSS技巧 本翻译并未得到作者或网站授权。一切权利都归原作者及原网站所有。如果你得到原作者或原发表网站的授权,可以自由使用本翻译。1.CSS字体属性简

一点小小的创意css鼠标放上去则显示电话号码 1,default:2,鼠标移上去:来源:今天在同事的手机的电话薄里面发现的,发现他存的电话号码都是显示名字,然后只要往下移动,就能显示这个人的相应

固定表格的高度超过指定高度就隐藏的方法 经常做网页,可发现原理只用控制td的高度,超过了就隐藏是不能用的,应该还有其它的方法,后来发现,原理,只需要在td.../td中加个divstyle="height:px;

标签: 深入理解typescript 豆瓣

本文链接地址:https://www.jiuchutong.com/biancheng/375150.html 转载请保留说明!

上一篇:创建IE各版本专属CSS IE中的if语句(创建ie浏览器)

下一篇:一点小小的创意css鼠标放上去则显示电话号码(简单的小创意)

  • 个体户可选择不交税吗
  • 初装费包括什么
  • 累进税率的税种有哪些
  • 季报需要注意什么
  • 销项减进项余额在哪方
  • 机耕道属于水利还是土地整治
  • 过桥过闸通行费会计分录
  • 管理费用为负数可以申报吗
  • 经营租赁违约金可以直接冲租赁费
  • 公司并购股权转让协议
  • 代扣代缴个人所得税
  • 房租当月无发票怎么办
  • 房地产活动礼品送什么比较吸引人
  • 外汇收不到会不会丢
  • 开办公用品发票需要清单吗
  • 烟酒销售公司要交哪些税
  • 企业所得税税前不得扣除的项目
  • 四点帮你避开虚开发票
  • 小配件出口怎么报关
  • 开发票回款是什么意思
  • 计提专项借款本月利息会计分录
  • 损益类账户包括成本类吗
  • 税金及附加包括地方教育费附加吗
  • 打印的行程单可以删除吗
  • kali linux安装kde桌面
  • 土地用于自建项目怎么办
  • 月末计提电费
  • 存量资金上缴国库是哪个文件规定了
  • 没收的定金 会计分录
  • php开源软件
  • linux系统备份整个硬盘的命令
  • hp是什么软件
  • php连接mysql数据库的几种方式及区别
  • elementui ts
  • 印花税减半征收优惠政策2020
  • Vue Admin Template关闭eslint校验,lintOnSave:false设置无效解决办法
  • Vue:element-ui中表格过长内容隐藏显示
  • php下载文件夹
  • 前端解决跨域问题的8种方案(最新最全)
  • 开发票的零税率和免税有什么区别
  • nodejs写后端接口
  • 发票中食品属于哪一类
  • 公司车辆出售需要什么手续
  • day29--Java泛型02
  • python搞自动化
  • 无形资产资产处置损益和营业外收入
  • 单位上社保需要个人提供什么资料
  • 企业电子发票重开流程
  • 公司注销之前需要做些什么
  • 长期股权投资会计准则2021修订
  • SQL Server通过重建方式还原master数据库
  • 外贸公司出口退税流程
  • 资本公积账务处理办法
  • 公司购买手表可以做费用吗?
  • 企业招待客户收入怎么算
  • 应付账款清账账务处理
  • 母子公司之间无偿划转固定资产
  • 无息的银行承兑汇票
  • 用白纸写的收据怎么入帐?
  • 计提以前年度应付股利的分录
  • 离线发票累计金额是多少
  • 转售水电费收入确认
  • 执行企业会计准则和小企业会计准则的区别
  • 购买固定资产是应付账款还是其他应付款
  • excel日记账系统的设置
  • 寻找sql注入漏洞存在哪几个关键点
  • Kaspersky Rescue Disk 2009.04.16 卡巴斯基救援盘
  • 深入了解XP中“最后一次正确配置”功能
  • mac怎么安装字体到ai
  • cad2007字体怎么调大小
  • win7如何查询电脑使用记录
  • js布尔类型用法
  • javascript 作用域
  • unity触摸屏控件
  • 安卓app性能测试
  • 一些常用的网络命令
  • Python调用大漠插件
  • javascript面向对象精要
  • 税务申报显示重名怎么办
  • 进项转出怎么做
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设