金沙澳门官网网址h5开发相关内容总结

作者: 前端知识  发布:2019-07-18

移动端 h5开发相关内容总结:CSS篇

2016/01/24 · CSS, HTML5 · 1 评论 · 移动端

本文作者: 伯乐在线 - zhiqiang21 。未经作者许可,禁止转载!
欢迎加入伯乐在线 专栏作者。

移动端 h5开发相关内容总结——CSS篇

1.移动端开发视窗口的添加

h5端开发下面这段话是必须配置的

XHTML

meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">

1
meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">

其它相关配置内容如下:

  • width viewport 宽度(数值/device-width)
  • height viewport 高度(数值/device-height)
  • initial-scale 初始缩放比例
  • maximum-scale 最大缩放比例
  • minimum-scale 最小缩放比例
  • user-scalable 是否允许用户缩放(yes/no)
  • minimal-ui iOS 7.1 beta 2 中新增属性(注意:iOS8 中已经删除),可以在页面加载时最小化上下状态栏。

移动端开发视窗口的添加

  1. 媒体查询的改进
  2. a标签内容语义化
  3. 为自己的页面设置最大宽度和最小宽度
  4. 去掉 ainput 在移动端浏览器中的默认样式
    1. 禁止 a 标签背景
    2. 禁止长按 aimg 标签长按出现菜单栏
    3. 流畅滚动
  5. CSS 截断字符串
  6. calc 相关问题
  7. box-sizing 的使用
  8. 水平垂直居中的问题
  9. css 中 line-height 的问题
  10. 使用 vertical-align 调整图标垂直居中
  11. flex 弹性盒模型的使用

什么时候使用 flex 属性

添加厂商前缀

flex低版本浏览器的兼容

  1. CSS3动画性能的问题

2.媒体查询的改进

之前在做移动端开发的时候,为了适配多屏幕。使用的是rem 单位。这个时候就需要根据屏幕的尺寸来来动态的设置根节点htmlfont-size 值。这样可以解决多屏幕适配的问题。
比如下面的 媒体查询代码

XHTML

html { //iphone5 font-size: 62.5%; } @media (max-width: 414px) { html { //iphone6 font-size: 80.85%; } } @media (max-width: 375px) { html { //iphone6 font-size: 73.24%; } }

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
html {
    //iphone5
    font-size: 62.5%;
}
@media (max-width: 414px) {
    html {
        //iphone6
        font-size: 80.85%;
    }
}
@media (max-width: 375px) {
    html {
        //iphone6
        font-size: 73.24%;
    }
}

这样做的结果,有两个很明显的缺点

  • 适配屏幕的尺寸不是连续的。
  • 在自己的 css 文件中添加大段的这样查询代码。增加了 css 文件的体积。

后来参考淘宝移动端页面适配规则,使用 js 获取客户端的宽度,根据设计稿的原型动态的计算font-size 的值。

详细的内容请看这里 根据iPhone6设计稿动态计算rem值

1.移动端开发视窗口的添加

h5端开发下面这段话是必须配置的

<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">

其它相关配置内容如下:

width viewport 宽度(数值/device-width)

height viewport 高度(数值/device-height)

initial-scale 初始缩放比例

maximum-scale 最大缩放比例

minimum-scale 最小缩放比例

user-scalable 是否允许用户缩放(yes/no)

minimal-ui iOS 7.1 beta 2 中新增属性(注意:iOS8 中已经删除),可以在页面加载时最小化上下状态栏。

3.a标签内容语义化

大多数时候我们都会给一片区域加上点击跳转的功能。如下图:

金沙澳门官网网址 1

很可能我们商品区域都是使用的div 标签。很容易我们会给最外层加上一个 a 标签。因为a 是行内元素,是没有宽和高的。不能够把容器撑开。
一种解决办法就是给a 标签设置block 属性。如下:

XHTML

<style> a{display:block;} </style> <a> <div></div> </a>

1
2
3
4
5
6
7
<style>
    a{display:block;}
</style>
 
<a>
    <div></div>
</a>

功能上已经没有问题。但是在语义化的层面上,上面的代码是不标准的。

最好的做法就是做如下的修改,这样不会使自己的 html 代码显的太突兀:

XHTML

<style> a{display:block;} span{dispaly:block;} </style> <a> <span></span> <span></span> <span></span> </a>

1
2
3
4
5
6
7
8
9
10
<style>
a{display:block;}
span{dispaly:block;}
</style>
 
<a>
    <span></span>
    <span></span>
    <span></span>
</a>

2.媒体查询的改进

之前在做移动端开发的时候,为了适配多屏幕。使用的是rem 单位。这个时候就需要根据屏幕的尺寸来来动态的设置根节点html 的font-size 值。这样可以解决多屏幕适配的问题。
比如下面的 媒体查询代码

html {

    //iphone5

    font-size: 62.5%;

}@media (max-width: 414px) {

    html {

        //iphone6

        font-size: 80.85%;

    }

}@media (max-width: 375px) {

    html {

        //iphone6

        font-size: 73.24%;

    }

}

这样做的结果,有两个很明显的缺点

适配屏幕的尺寸不是连续的。 

在自己的 css 文件中添加大段的这样查询代码。增加了 css 文件的体积。

后来参考淘宝移动端页面适配规则,使用 js 获取客户端的宽度,根据设计稿的原型动态的计算font-size 的值。

详细的内容请看这里 根据iPhone6设计稿动态计算rem值

4.为自己的页面设置最大宽度和最小宽度

如果我们使用的是rem 单位,使用 js 动态计算font-size 值的话,我们可以无限适配最大和最小的终端屏幕。但是当用户的屏幕超过一定的尺寸以后还继续显示h5页面的话对用户会很不友好。
我们参看下京东和淘宝的h5 页面

金沙澳门官网网址 2
金沙澳门官网网址 3

我们看到了都是定义了页面的最大和最小宽度。这样在屏幕超过一定的尺寸以后可以更友好的展示(当然这不是必须的)。

我给自己的产品页面定义的最大的宽度和最小宽度分别是:

CSS

{ max-width:640px; min-width:320px; }

1
2
3
4
{
    max-width:640px;
    min-width:320px;
}

3.a标签内容语义化

大多数时候我们都会给一片区域加上点击跳转的功能。如下图:

 

很可能我们商品区域都是使用的div 标签。很容易我们会给最外层加上一个 a 标签。因为a 是行内元素,是没有宽和高的。不能够把容器撑开。
一种解决办法就是给a 标签设置block 属性。如下:

<style>

    a{display:block;}</style>

<a>

    <div></div></a>

功能上已经没有问题。但是在语义化的层面上,上面的代码是不标准的。

最好的做法就是做如下的修改,这样不会使自己的 html 代码显的太突兀:

<style>

 a{display:block;}

 span{dispaly:block;}

</style>

 

<a>

    <span></span>

    <span></span>

    <span></span>

</a>

5.去掉 a,input 在移动端浏览器中的默认样式

4.为自己的页面设置最大宽度和最小宽度

如果我们使用的是rem 单位,使用 js 动态计算font-size 值的话,我们可以无限适配最大和最小的终端屏幕。但是当用户的屏幕超过一定的尺寸以后还继续显示h5页面的话对用户会很不友好。
我们参看下京东和淘宝的h5 页面

 

我们看到了都是定义了页面的最大和最小宽度。这样在屏幕超过一定的尺寸以后可以更友好的展示(当然这不是必须的)。

我给自己的产品页面定义的最大的宽度和最小宽度分别是:

{

    max-width:640px;

    min-width:320px;}

1.禁止 a 标签背景

在移动端使用 a标签做按钮的时候,点按会出现一个“暗色”的背景,去掉该背景的方法如下

CSS

a,button,input,optgroup,select,textarea { -webkit-tap-highlight-color:rgba(0,0,0,0); /*去掉a、input和button点击时的蓝色外边框和灰色半透明背景*/ }

1
2
3
a,button,input,optgroup,select,textarea {
    -webkit-tap-highlight-color:rgba(0,0,0,0); /*去掉a、input和button点击时的蓝色外边框和灰色半透明背景*/
}

5.去掉 a,input 在移动端浏览器中的默认样式

2.禁止长按 a,img 标签长按出现菜单栏

使用 a标签的时候,移动端长按会出现一个 菜单栏,这个时候禁止呼出菜单栏的方法如下:

CSS

a, img { -webkit-touch-callout: none; /*禁止长按链接与图片弹出菜单*/ }

1
2
3
a, img {
    -webkit-touch-callout: none; /*禁止长按链接与图片弹出菜单*/
}

1.禁止 a 标签背景

在移动端使用 a标签做按钮的时候,点按会出现一个“暗色”的背景,去掉该背景的方法如下

a,button,input,optgroup,select,textarea {

    -webkit-tap-highlight-color:rgba(0,0,0,0); /*去掉a、input和button点击时的蓝色外边框和灰色半透明背景*/}

3.流畅滚动

CSS

body{ -webkit-overflow-scrolling:touch; }

1
2
3
body{
    -webkit-overflow-scrolling:touch;
}

2.禁止长按 a,img 标签长按出现菜单栏

使用 a标签的时候,移动端长按会出现一个 菜单栏,这个时候禁止呼出菜单栏的方法如下:

a, img {

    -webkit-touch-callout: none; /*禁止长按链接与图片弹出菜单*/}

6.CSS 截断字符串

单行截断字符串,这里必须指定字符串的宽度

CSS

{ /*指定字符串的宽度*/ width:300px; overflow: hidden; /* 当字符串超过规定长度,显示省略符*/ text-overflow:ellipsis; white-space: nowrap; }

1
2
3
4
5
6
7
8
{
    /*指定字符串的宽度*/
    width:300px;  
    overflow: hidden;  
    /* 当字符串超过规定长度,显示省略符*/
    text-overflow:ellipsis;  
    white-space: nowrap;  
}

3.流畅滚动

body{

    -webkit-overflow-scrolling:touch;}

7.calc 相关问题

之前在做布局的时候使用calc 出现了很严重的线上 BUG。后来就深究了下这个属性的使用。
calc好用的地方就是,可以在任何单位之间进行换算。但是浏览器支持的不是很好。看一下 can i use 截图:

金沙澳门官网网址 4

而且在使用的时候要加上厂商前缀,达到兼容性。不过现在不推荐使用,毕竟,浏览器支持有限。
示例代码:

CSS

#formbox { width: 130px; /*加厂商前缀,操作符( ,-,*,/)两边要有空格)*/ width: -moz-calc(100% / 6); width: -webkit-calc(100% / 6); width: calc(100% / 6); border: 1px solid black; padding: 4px; }

1
2
3
4
5
6
7
8
9
#formbox {
  width:  130px;
  /*加厂商前缀,操作符( ,-,*,/)两边要有空格)*/              
  width:  -moz-calc(100% / 6);  
  width:  -webkit-calc(100% / 6);  
  width:  calc(100% / 6);  
  border: 1px solid black;
  padding: 4px;
}

研究过淘宝,天猫,京东的 h5端页面看到这个单位用的不多,主要还是兼容性的问题吧。

6.CSS 截断字符串

单行截断字符串,这里必须指定字符串的宽度

{

    /*指定字符串的宽度*/

    width:300px;   

    overflow: hidden;  

    /* 当字符串超过规定长度,显示省略符*/

    text-overflow:ellipsis;  

    white-space: nowrap;   }

本文由金沙澳门官网发布于前端知识,转载请注明出处:金沙澳门官网网址h5开发相关内容总结

关键词: 金沙澳门官网

上一篇:动画的回调
下一篇:没有了