腾讯移动-Web-前端知识库学习一

640次阅读

共计 10741 个字符,预计需要花费 27 分钟才能阅读完成。

移动端 Web 解决方案学习:
(一)代码结构规范

使用 Mobile Boilerplate
在官网 (https://html5boilerplate.com/) 下载之后的目录结构:


CSS
该目录应包含项目的所有 CSS 文件。它包含一些初始 CSS,以帮助您从一个坚实的基础开始。关于 CSS。
DOC
该目录包含所有 HTML5 Boilerplate 文档。您可以将它用作您自己项目文档的位置和基础。
JS
该目录应包含项目的所有 JS 文件。这里可以包含库,插件和自定义代码。它包含一些初始的 JS 来帮助您入门。关于 JavaScript。
.htaccess
默认的 Web 服务器配置适用于 Apache。有关更多信息,请参阅 Apache Server Configs 存储库。
在 Apache 以外的服务器上托管您的站点?您可能会在我们的 Server Configs 存储库中找到相应的服务器配置项目。
404.html
一个有用的自定义 404,可以帮助您入门。
browserconfig.xml
此文件包含有关 IE11 和 Edge 的自定义切片的所有设置。
有关此主题的更多信息,请参阅 Microsoft 的文档。
.editorconfig
.editorconfig 提供该文件是为了鼓励和帮助您和您的团队在不同的编辑器和 IDE 之间保持一致的编码风格。了解更多有关.editorconfig 文件。
index.html
这是默认的 HTML 框架,应构成您网站上所有网页的基础。如果您使用的是服务器端模板框架,则需要将此初始 HTML 与您的设置集成。
如果您修改目录结构,请确保更新引用的 CSS 和 JavaScript 的 URL。
如果您使用的是 Google Universal Analytics,请确保编辑底部的相应代码段以包含您的分析 ID。
humans.txt
编辑此文件以包含在您的网站 / 应用上工作的团队以及为其提供支持的技术。
robots.txt
编辑此文件以包含您需要从搜索引擎隐藏的任何页面。
图标
替换默认 favicon.ico,tile.png,tile-wide.png 和苹果触摸图标用自己的。
如果您想针对不同的分辨率使用不同的 Apple Touch 图标,请参阅相应的文档。
(二)字体设计方案
body {

font-family: -apple-system, BlinkMacSystemFont, "PingFang SC","Helvetica Neue",STHeiti,"Microsoft Yahei",Tahoma,Simsun,sans-serif;}

iOS 4.0+(iOS 9 以下系统已经非常少)使用英文字体 Helvetica Neue,之前的 iOS 版本降级使用 Helvetica。中文字体设置为华文黑体 STHeiTi。
iOS 9+ Safari 开始支持 -apple-system 参数,Chrome 使用 BlinkMacSystemFont,兼容 iOS / MacOS
微软雅黑是为了兼容 Win 系统
需补充说明,华文黑体并不存在 iOS 的字体库中
但系统会自动将华文黑体 STHeiTi 兼容命中系统默认中文字体黑体 - 简或黑体 - 繁:
Heiti SC Light 黑体 - 简 细体
Heiti SC Medium 黑体 - 简 中黑
Heiti TC Light 黑体 - 繁 细体
Heiti TC Medium 黑体 - 繁 中黑
Android 就直接让它命中系统字体吧,因为你无法预知发行厂商会去内置什么字体,或者人家 root 去修改什么字体。
(三) 模拟原生效果实践
(1) css 实现类似物理 1 像素:
IOS 中的 border:


border 是一根非常细的线.
在实现 1px 物理像素之前,首先需要了解的知识:
1>设备像素比 devicePixelRatio 简单介绍
定义:window.devicePixelRatio(设备像素比)是设备上物理像素和设备独立像素 (device-independent pixels (dips))
的比例。
公式表示就是:window.devicePixelRatio = 物理像素 / dips
dip 或 dp,(device independent pixels,设备独立像素)与屏幕密度有关。
dip 可以用来辅助区分视网膜设备还是非视网膜设备。
所有非视网膜屏幕的 iphone 在垂直的时候,宽度为 320 物理像素。
当你使用 <meta name=”viewport” content=”width=device-width”> 的时候,
会设置视窗布局宽度(不同于视觉区域宽度,不放大显示情况下,两者大小一致,见下图)为 320px,
于是,页面很自然地覆盖在屏幕上。


这样,非视网膜屏幕的 iphone 上,屏幕物理像素 320 像素,独立像素也是 320 像素,因此,window.devicePixelRatio 等于 1
而对于视网膜屏幕的 iphone,如 iphone4s, 纵向显示的时候,屏幕物理像素 640 像素。
同样,当用户设置 <meta name=”viewport” content=”width=device-width”> 的时候,
其视区宽度并不是 640 像素,而是 320 像素,这是为了有更好的阅读体验 – 更合适的文字大小。
这样,在视网膜屏幕的 iphone 上,屏幕物理像素 640 像素,
独立像素还是 320 像素,
因此,window.devicePixelRatio 等于 2.
当页面设置了 <meta name=”viewport” content=”width=device-width”> 时候,
document.documentElement.clientWidth 在大部分浏览器下,
得到的是布局视区的宽度,等同于 dips(独立像素)的宽度。
对于 screen.width 的值:
在 iOS 视网膜设备上,screen.width 返回 dips 宽。
因此,在竖着显示的时候,视网膜显示屏的 ipad 和非视网膜显示屏的 ipad 返回的都是 768.
(结论)
devicePixelRatio 在大多数浏览器是值得信赖的。
在 iOS 设备,screen.width 乘以 devicePixelRatio 得到的是物理像素值。
在 Android 以及 Windows Phone 设备,screen.width 除以 devicePixelRatio 得到的是设备独立像素 (dips) 值。
(设备像素比原文链接:https://www.zhangxinxu.com/wo…
2>CSS3 border-image 详解、应用及 jQuery 插件
border-image:
兼容性:
目前支持的浏览器有限,仅 Firefox3.5,chrome 浏览器,Safari3+

(2016 年之后)
现在 IE11+,FireFox 以及 Chrome 浏览器均已支持 border-image,并且目前也就 Android4.3 及其以下版本需要 -webkit- 私有前缀,可以说 border-image 的时代即将到来。
特性:
类比 background:url(xx.jpg) 27px no-repeat;
border-image 包括图片,剪裁位置(与 background 位置一样,也是数值,也支持百分值),重复性。
例如:border-image:url(border.png) 27 repeat;,指的就是图片(url(border.png)),剪裁位置(27),重复方式(repeat)。试着对比 background,这有助于 border-image 属性的记忆。
border-image 的参数就是上面提到的三个:图片,剪裁位置,重复性。


border-image 的数值参数其实是用来剪裁边框图片的,正好“哗哗四刀”切出了个九宫格的模型,需要用到九宫格模型帮助我们理解 border-image 的绘制原理


边框将 border-image 分成了九部分:border-top-image , border-right-image , border-bottom-image , border-left-image, border-top-left-image , border-top-right-image , border-bottom-left-image , border-bottom-right-image 以及中间的内容区域:

图中,橙红色的四个边角的菱形区域称为“角边框图片”,
在 border-image 中,角边框图片是没有任何展示效果的,不会平铺,不会重复,也不会拉伸,有点类似于视觉中盲点的意思。
而对边的四个橙黄色区域属于展示效果的作用区(也是边框宽度计算剩余区),
上下区域即 border-top-image 和 border-bottom-image 区域受到展示效果属性的第一个参数——水平方向效果影响:
如果为 repeat,则此区域图片会水平重复,
如果是 round,则此框框内的图片会水平平铺,
如果是 stretch,则此矩形域中的图片就会被水平拉伸。
中间的区域(左图的空白格)受到全部参数的作用,在水平和垂直两个维度上都有展示效果(平铺、拉伸等)。
DEMO:
拉伸:
.border_image{

width:400px;
height:100px;
border:1em double orange;
border-image:url(../image/border.png) 27;}


平铺:
.border_image{

width:400px;
height:100px;
border:1em double orange;
border-image:url(../image/border.png) 27 round; }

重复:
.border_image{

width:400px;
height:100px; 
border:1em double orange;
border-image:url(../image/border.png) 27 repeat;

}

这一个边角处的菱形都是被截掉的。
border-image 绘制原理简述

共存在两个九宫格,一个是边框图片,还有一个就是边框本身,九个方位关系一一对应。边框本身的特性让其变成了一个九宫格,四条边框交错,加上其围住的区域,正好形成一个九宫格。边框图片则是通过图片剪裁实现了九宫格。
调用边框图片
border-image 的 url 属性,通过相对或绝对路径链接图片。
边框图片的剪裁
border-image 的数值参数剪裁边框图片,形成九宫格。
执行重复属性
被填充至边框九宫格四个角落的的边框图片是不执行重复属性的。
上下的九宫格执行水平方向的重复属性(拉伸或平铺),
左右的格子执行垂直方向的重复属性,
而中间的那个格子则水平重复和垂直方向的重复都要执行。

border-image 效果的 jQuery 插件
jquery.borderImage.js(链接描述)

使用方法
$(‘#element’).borderImage(‘url(“border.png”) 30% 35% 40% 30%’);
(border-image 这里的原文链接 https://www.zhangxinxu.com/wo…

border 实现效果:
.border-1px {border-width: 1px 0;border-style: solid;border-color: #333;}

因为 devicePixelRatio 特性,在手机屏幕上,border 被放大到物理像素 2px 显示,在 iPhone 上就显得较粗。

使用 border-image 属性实现物理 1px

通常手机端的页面设计稿都是放大一倍的,如:为适应 iphone retina,
设计稿会设计成 640*960 的分辨率,图片按照 2 倍大小切出来,
在手机端看着就不会虚化,非常清晰。
同样,在使用 border-image 时,将 border 设计为物理 1px

.border-image-1px {border-width: 1px 0px;-webkit-border-image: url(“border.png”) 2 0 stretch;border-image: url(“border.png”) 2 0 stretch;}
border.png 也可以直接使用的 base64 替代:
.border-image-1px {border-width: 1px 0px;-webkit-border-image: url(“”) 2 0 stretch;}

使用 CSS3 transform 实现
.border-1px {position: relative;}
.border-1px:after {position: absolute;content: ”;top: -50%;bottom: -50%;left: -50%;right: -50%;-webkit-transform: scale(0.5);transform: scale(0.5);border-top: 1px solid #666;border-bottom: 1px solid #666;}
(2) Web App Icon 与启动图片实践

iOS 允许网站开发者像 NativeApp 一样在 iOS 设备的主屏幕为其网站添加一个启动 Icon,
这个代表着网站的 Icon 在苹果官方开发者文档里被称为“Web Clip”,
它的作用类似于桌面浏览器的书签,用户通过点击 Icon 能直接快速打开这个 url 的网站。

为了给某个网页或者整个网站指定一个漂亮的桌面启动图标,iOS Safari 提供了两个私有接口:
apple-touch-icon 和 apple-touch-icon-precomposed。
设置方法:
通过在页面 HTML 的头部添加 <link> 标签:
<link rel=”apple-touch-icon” href=”touch-icon-iphone.png” />
<link rel=”apple-touch-icon-precomposed” href=”touch-icon-precomposed.png” />
这两个标签都是用来指定桌面图标的,但两者有个细微的区别,
通过 apple-touch-icon 添加的图标是会带 iOS 图标统一的高光效果
通过 apple-touch-icon-precomposed 添加的图标则是设计原图,不带高光渐变效果的。
图片大小:
为了给不同的 iOS 设备指定其启动图标,在 iOS Human Interface Guide 中提到,推荐以下四种尺寸:
iOS 设备 最适尺寸 (px)
iPhone 和 iTouch 57 x 57
retina iPhone 和 retina iTouch 114 x 114
iPad 72 x 72
retina iPad 144 x 144
相应地,要指定不同分辨率的设备的图标,可以添加相应的 <link> 标签序列,官方建议的顺序是这样的:
<link rel=”apple-touch-icon” href=”touch-icon-iphone.png” />
<link rel=”apple-touch-icon” sizes=”72×72″ href=”touch-icon-ipad.png” />
<link rel=”apple-touch-icon” sizes=”114×114″ href=”touch-icon-iphone-retina.png” />
<link rel=”apple-touch-icon” sizes=”144×144″ href=”touch-icon-ipad-retina.png” />
通过 <link> 的 <sizes> 属性可以特别地声明这个图标是为哪种分辨率设备准备的,如果没有指明 <sizes> 属性的大小,则默认值为 57×57。

如果所有的 <link> 标签序列中都没有符合官方推荐的最适尺寸的话,
那么 iOS 会从所有比推荐的最适尺寸大的图标中选择尺寸最小的那一个,
如果所有的 <link> 标签序列中的图标都比当前推荐的最适尺寸小的话,
iOS 会从这些图片中自动选择最大的那个来作为启动图标。
特别地,如果整个页面都没有指定任何的 apple-touch-icon 的图标的话,
iOS 则会自动去网站根目录寻找有 apple-touch-icon 和 apple-touch-icon-precomposed 前缀的图标文件。
图片格式:
用于设置成为桌面启动图标的图片文件,可以是以下三种类别:
纯静态的图片图片的路径可以绝对路径、相对于当前页面的相对路径以及相对于网站根目录的路径。
目前发现不仅支持 png 格式的,jpg 和 gif 也在支持的列表中
/files/uploadimg/20130522/1005102.png
但如果是动态 gif 图片只会截取一帧(第一帧?)来显示
包含图片文件头的 HTTP REQUEST 可以不是一个静态的文件,而是由服务器返回的带有图片
文件比如 image/png 文件头的请求。就像我们常用的图片
占位图工具 http://getimg.in 的图片
http://getimg.in/144x144tcat
这个的优点是可以根据前端需要动态地返回不同的图片,缺点是,每次新的图片都需要请求服务器,从服务器下载
base64 格式的图片这是一个包含 png 文件头的长字符串,它可以是一张从静态图片转换的,也可以是从服务器返回的,还可以是 canvas 生成的。
data:image/png;base64,(xxxxxx)

[Web App Icon 原文链接][2]

(原文网址:https://github.com/AlloyTeam/…

正文完
 0