位置: 编程技术 - 正文

推荐深入理解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鼠标放上去则显示电话号码(简单的小创意)

  • 餐饮行业的成本率在多少才正常
  • 个体工商户季度不超过30万免增值税吗
  • 非居民企业税率表最新
  • 台账和明细账的区别
  • 零申报失败什么原因
  • 季度应收账款周转天数是按多少天除
  • 股票投资收益是指投资者从购入股票开始到出售为止整
  • 应交税费怎么做分录
  • 对公付款没有发票
  • 物业公司收到开发代付物业管理费怎么做账
  • 本月没开票怎么报税
  • 增值税发票小规模2023
  • 发票章盖收据会被税务局罚款吗
  • 申报水利基金减免性质在哪里找?
  • 产品售后服务规定
  • 营改增后新纳入增值税征税范围的有
  • 资产总计与负债和所有者权益总计不一致
  • 固定资产清理需要结转吗
  • 小规模纳税人如何计算增值税
  • 递延收益在现金流量表体现吗
  • 预缴企业所得税是含税数还是不含税
  • 融资租赁业务如何纳税
  • 法人股东分红如何申报所得税
  • 电脑右下角弹出网页没有×怎么关闭
  • Win11如何卸载microsoft edge浏览器
  • 你需要权限来执行操作是怎么回事
  • 购买不动产会计分录
  • 应交税金减免税款
  • php字符串赋值
  • w10如何删除微软拼音
  • 炫龙笔记本win10系统为什么没有关闭触控板
  • 向境外支付技术服务费怎里面的增值税怎么入账
  • u8销售类型怎么设置
  • 补缴企业所得税和滞纳金如何入账
  • 新税法减免项目
  • php限制接口调用次数
  • web前端开发期末试题及答案
  • 回迁房会被收回吗
  • java如何解析json字符串
  • 如何修改wordpress主题
  • 技术软件开发
  • 会计做账需要银行交易明细吗
  • 织梦cms怎么样
  • 个人独资企业计提的各种准备金支出不得扣除
  • sql server 2008数据库没有备份文件恢复
  • mysql批量查询
  • 交易性金融资产入账价值怎么计算
  • 以前年度损益影响当期损益吗
  • 上月计提多了怎么办
  • 负商誉的分录
  • 涉及无形资产的会计处理
  • 销售边角料的增值税率
  • 租金摊销会计分录
  • 公司账户转账转错了能退回来吗
  • 财务费用为零的原因
  • 小微企业营业外收入二级科目怎么
  • 合伙企业对外投资收益怎么纳税
  • 私立医院怎么做不被骗的事情
  • 单位社保缴费收费标准
  • 进口关税如何记账
  • 投资收益余额在贷方怎么结转
  • 电子发票是否是原件发票
  • 买入返售证券什么意思
  • Mysql执行sql文件
  • ubuntu配置yum
  • linux快捷命令
  • Linux内核级别的资源隔离机制是
  • win 10系统怎么提高网速
  • es6中的class常见使用场景
  • Android游戏开发教程
  • 右键菜单中添加文字
  • 批处理清空文本内容
  • android download(international)
  • shell脚本关闭指定程序
  • 安卓调用系统相机
  • 安卓桌面照片插件
  • 安卓实现单选题
  • js面向接口编程
  • 辽宁省地税社保缴费基数
  • 汽车票用什么查
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设