Mobile css的标准也是有些复杂的,与前一篇文章中提到的类似,之前存在着一个W3C制定的CSS Mobile Profile 1.0以及OMA的WAP CSS 1.0,事实上它们都是CSS 2.1的子集,而且内容非常接近,不同的是,WAP CSS 1.0针对移动设备加入了一些扩展,这些扩展通过-wap-前缀来实现。
后来,W3C将二者进行了整合,吸收了WAP CSS1.0的一些优点,推出了CSS Mobile Prifile 2.0规范,它也是CSS 2.1的一个子集。我们本文将主要讨论这个规范。
因为这是CSS 2.1的一个子集,那么我们对这个规范的内容应该不会陌生,我们通过这个表格可以很直观的看到CSS MP对CSS的支持情况:
支持的
不支持的
选择器
全局选择器(*)、类型选择器(比如h1, div, p等)、子选择器(p>span)、链接伪类 (:link,:visited)、动态伪类(:active, :focus)、类选择器、id选择器、分组(h1,h2,h3{}…) |
:first-child、:hover 、:lang() 伪类, :first-letter 、:first-line 伪元素, 兄弟选择器(比如h1 + p),属性选择器 (比如 a[href], a[target="_blank"]) |
背景和边框
background, background-color, background-image, background-repeat, background-attachment, background-position, border, border-width, border-color, border-style(注1) |
无 |
定位
position, top, right, bottom, left, z-index |
无 |
列表
list-style, list-style-image, list-style-type |
list-style-position |
基本的盒模型
display(注2), margin, padding, height, min-height, max-height, width, min-width, max-width, float, clear, visibility, overflow(注3), overflow-style(注4) |
无 |
色彩
color |
无 |
字体
font, font-family, font-style, font-variant, font-weight, font-size(注5) |
无 |
文字
text-indent, text-align, text-decoration(注6), text-transform, white-space |
word-spacing, letter-spacing, unicode-bidi |
线形
vertical-align(注7) |
line-height |
基本的用户界面
utline, outline-color, outline-style, outline-width |
cursor |
滚动
marquee-style, marquee-direction, marquee-play-count, marquee-speed |
无 |
@规则
@charset, @import, @media(注8), @namespace |
@page |
- 注1:border-style只支持常用的none、dotted、dashed、solid和inherit,其它的几个并没有被列入规范。
- 注2:display仅限于inline、block、list-item、none和inherit,不支持run-in和inline-block
- 注3:overflow只支持auto
- 注4:overflow-sytle只支持marquee值
- 注5:font-size只支持大小关键词,比如small、medium、bigger等,px、pt和百分比等不被支持。
- 注6:text-decoration只支持none、blink、underline和inherit等,overline、line-trough不被支持。
- 注7:vertical-align 只支持top, middle, bottom, baseline 和inherit。sub, super, text-top, text-bottom, 百分比和长度不被支持
- 注8:@media规则只支持 handheld 和all 媒体类型。
用法与浏览器支持
就像之前文章里面提到的那样,目前绝大多数的手机是支持XHTML Basic 1.0和XHTML MP 1.0标准的,这就意味着在某种程度上移动网站的HTML/XHTML代码是可以与桌面版的相兼容甚至完全一致的。甚至有些网站的移动版直接使用HTML 4/5或者XHTML 1.0的DTD。这样移动版网站可以直接通过handheld的media type来制定一个移动页面专用的CSS文件:
1
|
<link rel="stylesheet" media="handheld" href="">
|
绝大多数传统手机上的浏览器都支持handheld媒体类型,包括opera mini和windows mobile中的IE。
其实考虑到传统手机的自身的限制和移动网络速度的限制,通过media type来加载外部样式是不可取的,通常用于移动版页面的样式不多,而多加载一个外部样式的代价是巨大的。所以,大部分的网站的移动版采用在head中嵌入样式表的方式。
如果,你一定要采用外部样式的话,最好不要用@import,因为有些手机浏览器并不支持。
特别值得一提的是,mobile webkit(包括iphone safari和android chrome lite等)不支持handheld。
而在视觉上的差异,主要是字体的表现差异,这和各个手机浏览器有关,想要做的像素完美,不是件容易的事情。
总结
虽然,移动网站貌似不用考虑太多的功能,布局简单,功能简单,但是现实并没有想象中的那么简单。移动网站面临的最大的问题是浏览器众多,手机终端差别又很大,开发的时候,会遇到这种细节问题。
目前国内移动网站的前端开发,还处于起步阶段,随着iPhone和Android等智能手机的流行,针对高端智能手机设备的网站开发将逐渐盛行,如 @SMbey0nd 所言,Mobile Web风暴,即将席卷中国,对于这个相对较新的领域,我们还有很多事情要做。
其实本文仅仅涉及到Mobile CSS的一些非常基础的方面,希望可以抛砖引玉,引起更多的人研究和分享移动网站开发的前端技术和技巧,如果你有较深入的研究,欢迎通过前端观察与大家分享。
分享到:
相关推荐
这些事件是专门为移动设备设计的,让应用或网站能识别用户的触摸手势,从而提供流畅的滑动体验。 “支持手机触控设备的滑动浏览导航”意味着该解决方案不仅限于简单的图片展示,还包括了页面导航元素,使得用户可以...
**前端开源库-postcss-px2rem** 在前端开发中,随着移动优先和响应式设计的普及,CSS单位的转换成为了一个重要的问题。`postcss-px2rem` 是一个非常实用的开源库,它是基于 PostCSS 的插件,主要用于将 CSS 文件中...
"别具光芒——CSS属性、浏览器兼容与网页布局"这个主题涵盖了三个核心概念:CSS属性、浏览器兼容性和网页布局。 首先,我们来详细探讨CSS属性。CSS提供了无数的属性,如颜色、字体、大小、位置等,这些属性共同决定...
这个压缩包“css-mastery-16.zip”包含了书中所有章节的源代码实例,是学习和实践CSS设计模式的宝贵资源。 在深入学习这些源代码之前,首先我们需要理解CSS的基础概念。CSS(Cascading Style Sheets)是一种样式表...
CSS Ratiocinator自动重构您CSS并为您的网站生成一个新的样式表。 它可以通过在浏览器中检查站点的实时DOM并反向工程一个新的,更优雅的定义来捕获样式直至像素的方式来工作。 它解决了旧CSS样式相互冲突的问题。 在...
5. **响应式设计**:随着移动设备的普及,CSS3引入了媒体查询(`@media`),可以根据设备特性调整样式,实现跨设备的优化显示。 6. **动画与过渡**:CSS3也引入了动画(`animation`)和过渡(`transition`)功能,...
由于浏览器对某些自定义光标的支持程度不同,`css-cursor`库确保了这些自定义光标在各种浏览器中的表现一致,提供了一种跨平台的解决方案。它通过预定义的CSS类或者JavaScript API来实现这些光标的兼容性处理。 ###...
在本压缩包“html5-css-3d.rar”中,重点展示了CSS3的3D转换特性,用于创建引人注目的3D图形和动画效果。这个示例项目名为"css3-3d-tetra",可以推测它可能是一个利用CSS3 3D变换技术构建的四面体(tetra)图形的...
"normalize.css-5.0.0.zip"是一个包含最新版本5.0.0的normalize.css文件的压缩包,它提供了一个现代的、替代传统CSS重置的方法,以确保不同浏览器之间的样式表现更加一致,提升用户体验。 首先,我们需要理解什么是...
这个压缩包包含了名为"normalize.css-6.0.0"的核心文件,这是一个轻量级的样式表,用于确保不同浏览器之间的默认样式更加一致,从而简化开发流程。 首先,我们要理解什么是CSS重置。在不同的浏览器中,HTML元素默认...
"CSS-书中素材下载"这个资源提供了一些实例,旨在帮助学习者更好地掌握CSS的核心概念和实际运用。下面,我们将深入探讨这些案例可能涉及的CSS知识点,以及它们如何在网页设计中发挥作用。 1. **选择器与属性**:CSS...
"css-support"项目就是为了提供一个可靠且详尽的CSS浏览器支持信息来源,帮助开发者更好地理解和适应这种差异。 该项目的核心是收集和整理来自多个数据源的浏览器兼容性信息,确保开发者能够获取到最新的CSS特性在...
在网页设计中,CSS(Cascading Style Sheets)...在“css-layout-and-positioning-master”这个压缩包中,可能包含了一系列关于CSS布局与定位的实例和教程,通过学习和操作这些文件,你可以更好地理解和应用这些概念。
在这个“鼠标悬停hover样式-css-mouse-hover-master.zip”压缩包中,我们可以找到关于CSS如何实现鼠标悬停效果的一些示例和资源。 鼠标悬停(hover)是CSS中的一种伪类选择器,用于当用户将鼠标指针移动到元素上时...
6. **响应式设计**:随着移动设备的普及,确保CSS在各种屏幕尺寸和设备上的兼容性至关重要。使用媒体查询(`@media`)实现响应式设计,让页面在不同设备上都能良好显示。 7. **测试与调试**:使用浏览器开发者工具...
"css-template三列布局"指的是利用CSS来创建一种常见的网页布局模式,即页面分为三个等宽或不等宽的列。这种布局广泛应用于网站的头部、主体内容和侧边栏。接下来,我们将深入探讨如何实现这样的布局,并介绍一些...
标题中提到的《精通css-高级web标准解决方案》这本书籍,显然是专门针对web开发人员撰写的,内容涵盖CSS的基础知识和高级技巧,同时对于在不同浏览器中可能出现的兼容性问题提供了相应的解决方案。通过这本书,读者...
7. **响应式设计**:随着移动设备的普及,理解如何使用CSS进行响应式设计,使网站能在不同尺寸的屏幕上良好展示,是现代Web开发不可或缺的技能。 8. **预处理器**:CSS预处理器如Sass、Less和Stylus允许编写更模块...
为了让CSS在所有浏览器下兼容,开发者需要采取一系列策略和技术,包括使用条件性注释、特殊CSS规则、渐进增强和优雅降级等方法。此外,了解并掌握不同浏览器对CSS特性的支持程度也是至关重要的。通过这些方法,可以...