diff --git a/README.md b/README.md index dce3abf..81b25fa 100644 --- a/README.md +++ b/README.md @@ -3,23 +3,21 @@ Mars - mobile needs a hero 面向亿万用户级的移动端Web解决方案: -1. [代码结构规范](./solutions/project-structure.md) -2. [字体设置最佳实践](./solutions/font-family.md) -3. [模拟原生效果实践](./solutions/) -4. [工具类方法汇总](./tools/) -5. [iOS与Android平台上问题列表](./issues/) -6. [高性能Mobile Web开发](./performance/) -7. 类库依赖推荐 -8. [演示](./demos/) +* [代码结构规范](./solutions/project-structure.md) +* [字体设置最佳实践](./solutions/font-family.md) +* [模拟原生效果实践](./solutions/) +* [工具类方法汇总](./tools/) +* [iOS 与 Android 平台上问题列表](./issues/) +* [高性能 Mobile Web 开发](./performance/) +* [Omi Web组件框架](https://github.com/Tencent/omi) +* [特效制作解决方案 - css3transform](http://alloyteam.github.io/AlloyTouch/transformjs/) +* [触摸运动解决方案 - AlloyTouch](https://github.com/AlloyTeam/AlloyTouch) +* [Mobile 手势解决方案 - AlloyFinger](https://github.com/AlloyTeam/AlloyFinger) +* [Mobile 裁剪解决方案 - AlloyCrop](https://github.com/AlloyTeam/AlloyCrop) +* [Mobile 级联选择器](https://github.com/AlloyTeam/AlloyTouch/tree/master/select) +* [1kb代码搞定移动 Web 开发调试发布错误监控上报用户问题定位 - AlloyLever](https://github.com/AlloyTeam/AlloyLever) +* [小程序、小游戏以及 Web 通用 Canvas 渲染引擎 - Cax](https://github.com/dntzhang/cax) -AlloyTeam 邀请社区朋友一起参与完善 Mars,欢迎 [Fork](https://github.com/AlloyTeam/Mars/fork) & [Pull Request](https://github.com/AlloyTeam/Mars/pulls) +### [捐助Mars](http://alloyteam.github.io/donate.html) -### 贡献者 - -1. 元彦 -2. Johnny Kwok -3. maxzhang -4. Adams - -###[如何贡献?](https://github.com/AlloyTeam/Mars/wiki/%E5%A6%82%E4%BD%95%E8%B4%A1%E7%8C%AE%E5%86%85%E5%AE%B9) -> 腾讯 +腾讯 AlloyTeam 邀请社区朋友一起参与完善 Mars,欢迎 [Fork](https://github.com/AlloyTeam/Mars/fork) & [Pull Request](https://github.com/AlloyTeam/Mars/pulls) diff --git a/issues/README.md b/issues/README.md index c54168d..82fadff 100644 --- a/issues/README.md +++ b/issues/README.md @@ -99,6 +99,7 @@ click 事件普遍 300ms 的延迟 }); 把代码放在 setTimeout 中,会发现程序变快. + ### 关于 iOS 系统中,WebAPP 启动图片在不同设备上的适应性设置 @@ -135,7 +136,7 @@ Android web视图,例如在 HTC EVO 和三星的 Galaxy Nexus 中,文本输 参考: -###移动端 HTML5 audio autoplay 失效问题 +### 移动端 HTML5 audio autoplay 失效问题 这个不是 BUG,由于自动播放网页中的音频或视频,会给用户带来一些困扰或者不必要的流量消耗,所以苹果系统和安卓系统通常都会禁止自动播放和使用 JS 的触发播放,必须由用户来触发才可以播放。 @@ -153,7 +154,7 @@ document.addEventListener('touchstart', function () { 扩展阅读: -###移动端 HTML5 input date 不支持 placeholder 问题 +### 移动端 HTML5 input date 不支持 placeholder 问题 input type date 的 placeholder 支持性有一定问题,因为浏览器会针对此类型 input 增加 datepicker 模块,看上去没那么必要支持 placeholder。 @@ -180,7 +181,7 @@ input type date 的 placeholder 支持性有一定问题,因为浏览器会针 方案出处: -###IOS Safari 支持localstorage但是setItem异常(QUOTA_EXCEEDED_ERR:DOM Exception 22) +### IOS Safari 支持localstorage但是setItem异常(QUOTA_EXCEEDED_ERR:DOM Exception 22) 平台:IOS8.1 browser:Safari600.1.4 @@ -188,7 +189,8 @@ input type date 的 placeholder 支持性有一定问题,因为浏览器会针 问题源自于项目需要在浏览器中遮罩提示,点击关闭状态存储在localstorage中。Safari浏览器关闭后刷新页面层依旧存在 bug issue 简单的存储状态可以使用cookie的方式替代。 -###Chrome 地址栏自动隐藏交互行为对于fixed 顶部的元素遮挡 + +### Chrome 地址栏自动隐藏交互行为对于fixed 顶部的元素遮挡 系统:IOS8.1 浏览器:Chrome 26.0.1410.53 @@ -200,25 +202,27 @@ input type date 的 placeholder 支持性有一定问题,因为浏览器会针 bug fixed 解决办法在这里 -###Android平台遮罩层下的input、select、a等元素可以被点击和focus(点击穿透) +### Android平台遮罩层下的input、select、a等元素可以被点击和focus(点击穿透) 问题发现于三星手机,这个在特定需求下才会有,因此如果没有类似问题的可以不看。首先需求是浮层操作,在三星上被遮罩的元素依然可以获取focus、click、change. bug issue ,在查看bug报告list以后,找到了两种解决方案,第一是通过层显示以后加入对应的class名控制,第二是通过将可获取焦点元素加入的disabled属性,也可以利用属性加dom锁定的方式(disabled的一种变换方式) -###部分机型存在type为search的input,自带close按钮样式修改方法 +### 部分机型存在type为search的input,自带close按钮样式修改方法 有些机型的搜索input控件会自带close按钮(一个伪元素),而通常为了兼容所有浏览器,我们会自己实现一个,此时去掉原生close按钮的方法为 - #Search::-webkit-search-cancel-button{ - display: none; - } +```css +#Search::-webkit-search-cancel-button{ + display: none; +} +``` 如果想使用原生close按钮,又想使其符合设计风格,可以对这个伪元素的样式进行修改。 -###唤起select的option展开 +### 唤起select的option展开 zepto方式: ``` -$(sltElement).trrgger("mousedown"); +$(sltElement).trigger("mousedown"); ``` 原生js方式: ``` @@ -228,4 +232,4 @@ function showDropdown(sltElement) { event.initMouseEvent('mousedown', true, true, window); sltElement.dispatchEvent(event); }; -``` \ No newline at end of file +``` diff --git a/performance/README.md b/performance/README.md index 76b4295..76b135d 100644 --- a/performance/README.md +++ b/performance/README.md @@ -3,3 +3,5 @@ 1. [高性能CSS3动画](./high-performance-css3-animation.md) 2. [CSS动画属性性能](./css-property-animation-performance.md) +3. [高性能滚动](https://github.com/WICG/EventListenerOptions/blob/gh-pages/explainer.md) +4. [离线 Web App 以及消息同步与推送实现](https://developers.google.com/web/fundamentals/getting-started/primers/service-workers) diff --git a/solutions/README.md b/solutions/README.md index 62d8d8e..cb2d6e7 100644 --- a/solutions/README.md +++ b/solutions/README.md @@ -1,6 +1,6 @@ 模拟原生效果实践 ==== -1. [使用border-image实现类似物理1像素](./border-1px.md) +1. [CSS 实现类似物理1像素](./border-1px.md) 2. [ios] [Web App Icon与启动图片实践(1)](https://gist.github.com/tfausak/2222823) -2. [ios] [Web App Icon与启动图片实践(2)](http://mobile.51cto.com/web-395063.htm) +3. [ios] [Web App Icon与启动图片实践(2)](http://mobile.51cto.com/web-395063.htm) diff --git a/solutions/border-1px.md b/solutions/border-1px.md index fe98f29..6a9f84b 100644 --- a/solutions/border-1px.md +++ b/solutions/border-1px.md @@ -1,6 +1,6 @@ -使用border-image实现类似iOS7的1px底边 +CSS 实现类似原生效果的 1px 边框 ===== - +## 一.使用border-image实现类似iOS7的1px底边 iOS7已经发布有一段时间,扁平化设计风格有很多值得称赞的地方,其中有很多设计细节都是值得研究的。 首先,来看下面iOS设置的截图中的border: @@ -65,3 +65,23 @@ iOS7已经发布有一段时间,扁平化设计风格有很多值得称赞的 -webkit-border-image: url("") 2 0 stretch; } ``` + +## 使用 CSS3 transform 实现 + +```css +.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; +} +``` diff --git a/solutions/font-family.md b/solutions/font-family.md index c397ce3..3061aca 100644 --- a/solutions/font-family.md +++ b/solutions/font-family.md @@ -2,14 +2,21 @@ ```css body { - font-family: "Helvetica Neue", Helvetica, STHeiTi, sans-serif; + font-family: -apple-system, BlinkMacSystemFont, "PingFang SC","Helvetica Neue",STHeiti,"Microsoft Yahei",Tahoma,Simsun,sans-serif; + } ``` -iOS 4.0+ 使用英文字体 Helvetica Neue,之前的iOS版本降级使用 Helvetica。 - +iOS 4.0+ (iOS 9以下系统已经非常少) 使用英文字体 Helvetica Neue,之前的iOS版本降级使用 Helvetica。 中文字体设置为华文黑体STHeiTi。 +iOS 9+ Safari开始支持 -apple-system 参数, Chrome 使用 BlinkMacSystemFont ,兼容 iOS / MacOS + +`微软雅黑`是为了兼容Win系统,毕竟视网膜分辨率的win系统用`Simsun`是非常丑陋的,可以用4K屏 windows 去看 JD 淘宝,你能忍的话我就没话说 + +`PingFang SC` 是简体苹方,看需要 如果要命中对应 苹方字体的话 直接写 PingFang 不带引号。 + + 需补充说明,华文黑体并不存在iOS的字体库中(http://support.apple.com/kb/HT5484?viewlocale=en_US), 但系统会自动将华文黑体STHeiTi兼容命中系统默认中文字体黑体-简或黑体-繁: @@ -28,6 +35,8 @@ Heiti TC Medium 黑体-繁 中黑 其他第三方Android系统也一致选择默认的无衬线字体。 +Android 就直接让它命中系统字体吧,因为你无法预知发行厂商会去内置什么字体,或者人家root去修改什么字体。 + ## 参考阅读 * [Droid, the default font for older versions of Android](http://en.wikipedia.org/wiki/Droid_fonts) * [Roboto, the default font for newer versions of Android](http://en.wikipedia.org/wiki/Roboto) diff --git a/tools/README.md b/tools/README.md index fb46b59..b76270f 100644 --- a/tools/README.md +++ b/tools/README.md @@ -46,3 +46,7 @@ * [移动端手势表](http://ww1.sinaimg.cn/large/c2c57f68jw1e4fh7dmw12j20fi2w6qe1.jpg "移动端手势表") * [webkit独有的样式分析](http://ued.ctrip.com/blog/wp-content/webkitcss/ "webkit独有的样式分析") + +* [地图地区分布配色方案选择工具](https://github.com/axismaps/colorbrewer/ "地图地区分布配色方案选择工具") + +* [在线配色选择器](http://www.peise.net/tools/web/ "在线配色选择器")