网页设计技巧:跨浏览器的CSS固定定位

2016-02-19 17:26 0 1 收藏

图老师设计创意栏目是一个分享最好最实用的教程的社区,我们拥有最用心的各种教程,今天就给大家分享网页设计技巧:跨浏览器的CSS固定定位的教程,热爱PS的朋友们快点看过来吧!

【 tulaoshi.com - Web开发 】

跨浏览器的CSS固定定位{position:fixed}

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

不知道您是否留意了,浏览本站时,浏览器右下角有一个标着top的黑色直角三角形,可以点击它返回到正在浏览的网页页眉。当滚动网页时,它的位置一直没有任何改变,您感觉它怎么样?这就是通过CSS的定位属性{position:fixed}来实现的,通过它可以让HTML元素脱离文档流固定在浏览器的某个位置。

IE7、Firefox、Opera,都支持CSS的{position:fixed},所以很容易实现 IE6不支持该属性,但是在使用!DOCTYPE 声明指定standards-compliant(标准)模式可以通过CSS hack实现 上述声明下IE5和IE5.5目前没有发现通过纯粹CSS能够解决的方案,但是可以通过IE特有的expression在CSS中实现(移动网页时固定元素会动),这和常见浮动Logo广告利用Javascript实现原理是一样的,只不过可以直接写在CSS中比较简便的 利用IE独有的条件注释语句可以针对不同的IE版本精确设置,同时避免了这些代码被其他浏览器读到,个人认为比纯粹的CSS Hack好,如果你安装了多个IE(包括绿色版本),条件注释将会以最高版本的IE为标准。
实现代码如下:

"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"

……

/*IE6中利用容器对溢出内容的处理方式来实现的*/

!--[endif]--

!--[endif]--

……

{position:fixed}

代码演示1(单个IE,纯粹通过条件注释区分IE浏览器)

代码演示2(多个IE,通过条件注释+CSS hack区分IE浏览器,明显的比纯粹条件注释复杂且不易读,放上来主要是便于同个PC拥有多个IE浏览器朋友[一般应该做是web开发的]可以直接看到效果,下同。)

或许有人像我一样,在!DOCTYPE 声明是XHTML1.0 Strict或者是XHTML1.1时,喜欢在声明前面加上XML Prolog(如:),但此时IE7以下都处于quriks(兼容)模式,所以上述针对IE6的Hack失效,这个时候你可以对IE6也通过 expression来实现。

当IE6处于quriks模式时,IE6和IE5.5对CSS解析方式几乎雷同,所以当看到《position:fixed for Internet Explorer》时,我找到了在quriks模式下IE6/IE5.5/IE5统一的CSS解决方案:

"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"

……

!--[endif]--

……

{position:fixed}
代码演示3(单个IE,纯粹通过条件注释区分IE浏览器)

代码演示4(多个IE,通过条件注释+CSS hack区分IE浏览器)

对比两个纯粹的CSS hack发现,两个原理似乎相同,在于html元素和body元素的应用和对CSS的{position:fixed}的支持程度上,但是这实际上是一种 Hack,基本上不具备通用性,知道这个方法就可以了。需要提醒的是IE6 standards-compliant模式下HTML元素不管给它设置什么样的高度和宽度,它的大小都始终充满整个浏览器的可视区域,而IE5 以及 Quirks 模式下html元素和body元素所有宽高设置都会被忽略而保持充满浏览器的可视区域.

或许有人会想,现在可以引入了XML Prolog又能用纯CSS方法解决了IE7以下的问题,这下爽了,但是加上XML Prolog后突然发现IE6处于Quriks模式,以前在standards-compliant模式下的设计又变形了,呵呵,这就是咱们搞IE的下场

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

来源:https://www.tulaoshi.com/n/20160219/1615229.html

延伸阅读
标签: Web开发
原文: http://www.macji.com/blog/article/to-achieve-cross-browser-css-float-center/to-achieve-cross-browser-css-float-center/ 我们都知道float:left和float:right,但是否想过float:center呢?居中浮动。。。 div id="macji"     ul class="macji-skin"       ...
标签: ASP
使用XML存储的数据给我们带来了极大的方便,而且,XML是跟平台无关的。利用XSLT可以将XML转换成任意格式的文档,比如HTML。另外还可以使用这种方法来实现跨平台浏览器(IE,火狐,WAP浏览器等)的支持。比如用如下 ASP 代码获取客户端浏览器类型: <% Dim objBrowsCap Set objBrowsCap = Server .CreateObject("MSWC.BrowserType") ...
标签: Web开发
网页设计遇到最大的麻烦之一莫过于网页对不同浏览器的兼容性问题了,因为IE 6.0 / IE 7.0 / firefox 2 / Opera 9等主流浏览器对CSS解析不近相同,导致设计的页面效果不一样,所以用什么方法可以有效解决不同浏览器不同页面效果的问题呢?广泛被使用的方法就是CSS Hack,即使用特别的CSS定义显示网页在不同浏览器的设计风格,针对不同的浏览器去...
标签: 浏览器
360浏览器整张网页截图的技巧   在聊天过程中,截图来说说,是在所难免的,但有的网友想要趴别人网站的网页,就想要整个网页截图,这时截图功能就会失效,其实在浏览器中就可以讲整个网页截图下来,下面我们以360浏览器为例来进行讲解。 360浏览器的方法: 1 首先我们要打开你的360浏览器,没有的自己去下载安装吧,然在...
360安全浏览器跨屏浏览怎么关闭 1、打开360安全浏览器,点击右上角的工具--选项; 2、点击左侧的“实验室”,在右侧取消勾选“显示跨屏浏览按钮”、“在状态栏显示跨屏浏览图标”和“开启自动同步功能”即可。 如何将电脑上的网页同步到手机 1、打开一个网页,点击右上角的跨屏浏览按钮。 2、在弹出的页面...

经验教程

955

收藏

81
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部