安卓手机怎么连接网络上从应用里面点击连接到一个浏览器网页无法打开显示“请解除屏幕锁定后横屏进行。”请问怎么做?

[网页设计]手机浏览器页面点击不跳转(Android手机部分浏览器) 浏览器双击放大网页 解决
你的位置:
[网页设计]手机浏览器页面点击不跳转(Android手机部分浏览器) 浏览器双击放大网页 解决
手机浏览器页面点击不跳转 浏览器双击放大网页 解决 - 微..._博客园网页项目开发过程中,使用PC浏览器能正常访问,IOS设备浏览器也能正常访问,但是使用Android部分浏览器进行访问的时候,链接偶尔不跳转,点击完没有任何反...Android WebView或手机浏览器打开连接问题解决办法总结这篇文章主要介绍了Android WebView或手机浏览器打开连接问题解决办法总结的相关...重写此方法表明点击网页里面的链接还是在当前的webview里跳转,不跳...手机什么浏览器可以不跳转到wap网页(触屏版网页),就跟i..._百度知道1个回答 - 提问时间: 日你好,建议你试试手机QQ浏览器。 我一直用感觉不错,挺好用的 它有自主研发的X5内核。所以上网的速度是很快的, 它的安装包只有小小的4m.可以为你升级...更多关于手机浏览器页面点击不跳转(Android手机部分浏览器) 浏览器双击放大网页 解决的问题&&怎么让Android 浏览器焦点在文本输入框时不自动放大页面? - 知乎android上面的浏览器,点击网页上的文本输入框的时候,会自动把网页放大,请问一下网页代码上使用javascript之类的怎么可以取消这个功能?显示全部 ...安卓手机浏览器自动跳转垃圾页面怎么办啊_百度知道3个回答 - 最新回答: 日[]具体解决办法如下: 1,C:\Program Files\Inte Explorer到这里找到浏览器——〉发送到桌面快捷方式,用这个。 2,删除地址栏的快捷方式,也换成上面那个...更多关于手机浏览器页面点击不跳转(Android手机部分浏览器) 浏览器双击放大网页 解决的问题&&给手机浏览器增加网页翻译功能_安卓系统_UC论坛10条回复&-&发帖时间:&日平时经常需要上一些外国网站搜集素材,所以浏览器网页翻译功能对我来说必不可少,...平时我们打开一个网页时,点击收藏夹里的某个书签的话,那么这个页面...Android调用手机浏览器打开某网页出现异常情况 - CSDN博客android /浏览器 /uri /2656 编辑 删除 点击某个控件,比如Button,ImageView或者ImageButton之类的控件,用浏览器打开某个网址,如csdn:“csdn” 该控件...如何在手机浏览器网页中点击链接跳转到微信界面_QQ技巧_QQ地带如何在手机浏览器网页中点击链接跳转到微信界面时间: 09:46 作者:QQ地带 我要评论 纯属个人研究,转载请注明出处,谢谢。 从网页跳转到微信,...阻止手机浏览器双击放大的方法 -百家号如果博通吞并高通,中国手机行业就危险了 王云辉 百度新闻客户端 Android版下载 ...不断的点击按钮来发更多的电量,这不断的点击会触发双击的动作,浏览...彻底解决手机浏览器无法下载文件的症结,就这么简单 - M..._机锋论坛6条回复&-&发帖时间:&日ox-Android-14.0.apk PS:以我非专业的头脑看来,手机浏览器跟桌面浏览器的编码根本不同,而大部分网页都是为桌面浏览器做的,所以手机浏览器需要进行转码...安卓手机浏览器哪个好 六大主流浏览器推荐 - 站长之家随着移动互联网的普及,通过手机上网的方式也得到了广泛的使用,然而手机中自带浏览器的使用速度,却远远跟不上用户苛刻的需求,导致很多用户都会为自己的....../平板浏览器上网增加英文外文网页翻译成中文功能!iOS/Android/...页面就会跳转到异次元的网站去了,而 Bookmarklet 则是直接在当前的网页中执行...由于手机版的 Chrome 浏览器在点击书签后会打开新的网页而不能正确执...傲游手机浏览器下载_傲游手机浏览器4.0安卓版下载_网页浏览_下载...傲游手机浏览器是基于Android系统研发的一款WAP网页浏览软件,提供收藏数据同步服务的网页浏览软件,拥有手势、多标签快速浏览体验。 1.跨平台(手机、......浏览器中的网页调起微信支付的方案研究 - Android移..._红黑联盟如果我们的app打开第三方网页用的是手机浏览器的话,就不用做什么,直接可以调起微信支付了。按微信文档所说,应该大部分浏览器都支持,我只是简单测试了...手机浏览器页面如何用js关闭?-CSDN论坛19条回复&-&发帖时间:&日楼主解决,js 关闭手机浏览器的方法了没、、、 求指教啊 回复于: 2014-12-...帮顶,遇到同样的问题了,然后可以想到的方法差不多就一个,记录前一页面的u...使用电脑远程调试安卓手机上浏览器的JS_luo080428_新浪博客有时候要开发在手机浏览器上运行的网页,这样就涉及到要调试JS,在电脑上怎么模拟,跟使用真机还是有区别,这里介绍几种用电脑远程调试JS的方法。 1.使用...百度手机浏览器下载安装_百度手机浏览器官方免费下载..._华军软件园下载地址&&&华军软件园为您提供百度手机浏览器下载,百度手机浏览器官方下载。百度手机浏览器是一款简洁轻快、智能懂你的浏览器。百...浏览器网页判断手机是否安装IOS/Android客户端程序申请应用宝合作,依据应用宝提供的下载链接,跳转至应用宝界面,再点击下载,应用宝会依据手机设备的不同决定跳转至App store或者安卓应用宝的相应下载页......HTC手机论坛_安卓网_安卓论坛-中国最大Android手机交流社区 - ...9条回复&-&发帖时间:&日Wifi打开 qq能上 但浏览器打不开网页 是怎么回事呢...到待机界面。按“电话” 进入拨号面板输: *#*#4636...发表回复 回帖后跳转到最后一页用安卓手机,...、 、 、 、 、 、
手机端web网页项目(angluar js 1.4.6)1,网页项目开发过程中,使用PC浏览器能正常访问,IOS设备浏览器也能正常访问,但是使用Android部分浏览器进行访问的时候,链接偶尔不跳转,点击完没有任何反应(本人使用angluar js route进行单页面应用跳转),此时地址栏的路径已经被更新为点击后的地址.&解决方案:使用UC浏览器远程调试工具,在PC端chrome浏览器监控手机端web页面控制台,最后发现有时路由跳转导致代码报错:TypeError: Cannot read property 'runner' of undefined
at angular-animate.js:2330
at forEach (angular.js:336)
at closeChildAnimations (angular-animate.js:2325)
at queueAnimation (angular-animate.js:2148)
at Object.$$AnimateQueueProvider.$get.push (angular-animate.js:2040)
at Object.$AnimateProvider.$get.leave (angular.js:5200)
at cleanupLastView (angular-route.js:913)
at angular-route.js:942
at publicLinkFn (angular.js:7387)
at $get.boundTranscludeFn (angular.js:7533)`(1)此错误是因为引入angular-animate.js导致的错误,我虽然引用了这个文件,但是没有使用,所以直接删除即可。(2)如果项目中用到了angular-animate.js,那么只有升级angular.js版本了,其实这个错误是1.4.6版本的一个bug,在1.4.9版本修复了该问题,详情参考:https://github.com/angular/angular.js/issues/11992&2,双击网页放大问题:现在的手机或平板电脑等移动设备上的浏览器默认都有双击放大的设置,怎么让双击不放大?解决方案:可以在页面头部加上meta&meta name="viewport" content="width=device-width,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no" /&&最后问题解决&他的最新文章
他的热门文章
您举报文章:
举报原因:
原文地址:
原因补充:
(最多只允许输入30个字)mobileHack
这里收集了许多移动端上遇到的各种坑与相对解决方案
1.问题:手机端 click 事件会有大约 300ms 的延迟
原因:手机端事件 touchstart –& touchmove –& touchend or touchcancel –& click,因为在touch事件触发之后,浏览器要判断用户是否会做出双击屏幕的操作,所以会等待300ms来判断,再做出是否触发click事件的处理,所以就会有300ms的延迟
解决方法:使用touch事件来代替click事件,如 zepto.js 的tap事件和fastClick,还有我自己也写了个移动端手势操作库mTouch,都有相应的事件可以代替click事件解决这个问题
2.问题:在部分机型下(如小米4、小米2s、中兴) body 设置的 font-size 是用 rem 单位的话,若其他元素没有设置font-size,该font-size值继承于body,则会很高概率出现字体异常变大的情况
原因:估计是跟app的webview默认设置有关,body的font-size使用rem单位,就是相对于当前根节点的font-size来确定的,可能在某些webview的设置下,body用的是webview设置的默认字体大小,因为在我给html设置了一个px单位的默认font-size时,还是会出现字体异常变大的情况,具体webview的一些细节就没有再研究了
解决方法:body设置一个px单位的默认font-size值,不用rem,或者给字体会异常变大的元素设定一个px单位的font-size值&3.问题:使用zepto的 tap 事件时会出现“点透”bug,比如:一个元素A绑定了tap事件,紧跟其后的元素B绑定了click事件,A触发tap事件时将自己remove掉,B就会自动“掉”到A的位置,接下来就是不正常的情况,因为这个时候B的click事件也触发了
原因:因为tap事件是通过 touchstart 、touchmove 、 touchend 这三个事件来模拟实现的,在手机端事件机制中,触发touch事件后会紧接着触发touch事件坐标元素的click事件,因为B元素在300ms内刚好“掉”回来A的位置,所以就触发了B的click事件,还有zepto的tap事件都是代理到body的,所以想通过e.preventDefault()阻止默认行为也是不可行的
解决方法:(1)A元素换成click事件;(2)使用我写的库 mTouch 来给A绑定tap事件,然后在事件回调中通过e.preventDefault()来阻止默认行为,或者换用其他的支持tap事件的库
问题、4.动画
动画有很多种,比如侧边栏菜单的滑入滑出、元素的响应动画、页面切换之间的过场等等,在H5之下的众多实现方法都没有办法达到纯原生的性能。一般这些的话有几种不同的选择:动画,动画,原生动画。css3动画非常的消耗性能,如果某一个元素用到css3动画可能还看不出来,但大面积或过场使用css3动画会让app低端手机体验非常差。最好的选择一般是通过框架调用底层的动画,但不管怎么样等于在原来的代码上包上了一层,性能还是不可避免的受到影响。比如在一个新页面的载入上,如果调用底层动画要考虑的问题有两个,一个是本身资源页面的渲染问题,另一个是远程数据的获取。即便是这些动画能够很快的响应,但大量的css页面会导致渲染卡顿,滑入时可能会有白屏/机器卡顿的现象。为了解决这些性能问题又必须要用到预加载或模拟动画。即便是这样,滑入滑出的动画在低端的机器上还是有很多问题,如果获取服务端数据处理的方式不合适,卡顿白屏的现象会更严重。具体看下面的数据获取方式。
问题、5.获取服务端数据
首先要接受的是,这里的数据获取都是在资源页面上异步完成的,因为只有这样才能让这些资源页面完成预加载或者渲染。但是异步拿到的数据在填入页面中时可能会涉及DOM操作,众所周知,DOM操作非常消耗性能,如果页面小还好,页面稍稍微复杂一点,频繁的DOM操作会导致明显的闪白。而且最重要的一点是,如果页面加载进来之后数据更新的速度太慢,也会让页面模板等待很长时间,对用户体验又不友好,总不能每次打开都像浏览器一样等待刷新是吧。这个问题如果没有得到解决,H5APP是很难承担大规模数据的页面,在它们之中频繁切换更是难上加难,那么肯定有人也会想到用MVVM的方式,其实我也写过一些基于MVVM的H5APP,相对来说它们获取数据和更新数据的方式更更科学,但写的过程中又要注意很多H5独有的问题,这些问题在下面的页面切换里来讲。
一些有用技能点
通过设置css属性 -webkit-tap-highlight-color: rgba(0, 0, 0, 0);取消掉手机端webkit浏览器 点击按钮或超链接之类的 默认灰色背景色&设置css属性 -webkit-user-select: 控制用户不可选择文字&区域性 overflow: scroll | auto 滚动时使用原生效果:-webkit-overflow-scrolling: touch (ios8+,Android4.0+)
工具类网站
iphone6的那些事
响应式测试工具
Firefox 浏览器内置了&自定义设计视图&的功能,可以通过&Firefox-&Web 开发者-&自定义设计视图(或者摁下&Shift + Ctrl + m&)。相比网络工具,运行更加流畅,无需联网。
媒体查询常用样式表:
竖屏时使用的样式
//横屏时使用的样式
Web app 开发的最佳实践与中文总结
来自的一些移动端经验总结干货
本资料很多引用了指尖上的js系列
meta标签大全&
meta标签,这些meta标签在开发webapp时起到非常重要的作用
第一个meta标签表示:强制让文档的宽度与设备的宽度保持1:1,并且文档最大的宽度比例是1.0,且不允许用户点击屏幕放大浏览;&尤其要注意的是content里多个属性的设置一定要用分号+空格来隔开,如果不规范将不会起作用。
注意根据&&提供的资料补充,content 使用分号作为分隔,在老的浏览器是支持的,但不是规范写法。
规范的写法应该是使用逗号分隔,参考&&和&
width - viewport的宽度
height - viewport的高度
initial-scale - 初始的缩放比例
minimum-scale - 允许用户缩放到的最小比例
maximum-scale - 允许用户缩放到的最大比例
user-scalable - 用户是否可以手动缩放
第二个meta标签是iphone设备中的safari私有meta标签,它表示:允许全屏模式浏览;&第三个meta标签也是iphone的私有标签,它指定的iphone中safari顶端的状态条的样式;&第四个meta标签表示:告诉设备忽略将页面中的数字识别为电话号码
在设置了initial-scale=1 之后,我们终于可以以1:1 的比例进行页面设计了。&关于viewport,还有一个很重要的概念是:iphone 的safari 浏览器完全没有滚动条,而且不是简单的“隐藏滚动条”,&是根本没有这个功能。iphone 的safari 浏览器实际上从一开始就完整显示了这个网页,然后用viewport 查看其中的一部分。&当你用手指拖动时,其实拖的不是页面,而是viewport。浏览器行为的改变不止是滚动条,交互事件也跟普通桌面不一样。&(请参考:指尖的下JS 系列文章)
更详细的 viewport 相关的知识也可以参考
移动开发事件
touchstart //当手指接触屏幕时触发
touchmove //当已经接触屏幕的手指开始移动后触发
touchend //当手指离开屏幕时触发
touchcancel
gesturestart //当两个手指接触屏幕时触发
gesturechange //当两个手指接触屏幕后开始移动时触发
gestureend
屏幕旋转事件
onorientationchange
检测触摸屏幕的手指何时改变方向
orientationchange
touch事件支持的相关属性
targetTouches
changedTouches
clientX    // X coordinate of touch relative to the viewport (excludes scroll offset)
clientY    // Y coordinate of touch relative to the viewport (excludes scroll offset)
screenX    // Relative to the screen
screenY    // Relative to the screen
pageX     // Relative to the full page (includes scrolling)
pageY     // Relative to the full page (includes scrolling)
target     // Node the touch event originated from
identifier   // An identifying number, unique to each touch event
屏幕旋转事件:onorientationchange
判断屏幕是否旋转
function orientationChange() {
switch(window.orientation) {
  case 0:
alert("肖像模式 0,screen-width: " + screen.width + "; screen-height:" + screen.height);
  case -90:
alert("左旋 -90,screen-width: " + screen.width + "; screen-height:" + screen.height);
  case 90:
alert("右旋 90,screen-width: " + screen.width + "; screen-height:" + screen.height);
  case 180:
  alert("风景模式 180,screen-width: " + screen.width + "; screen-height:" + screen.height);
addEventListener('load', function(){
orientationChange();
window.onorientationchange = orientationC
JS 单击延迟
click 事件因为要等待单击确认,会有 300ms 的延迟,体验并不是很好。
开发者大多数会使用封装的 tap 事件来代替click 事件,所谓的 tap 事件由 touchstart 事件 + touchmove 判断 + touchend 事件封装组成。
WebKit CSS:
&,全面、方便查询,下面为常用属性。
①“盒模型”的具体描述性质的包围盒块内容,包括边界,填充等等。&css&-webkit-border-bottom-left-radius:&-webkit-border-top-left-radius: horizontal_radius vertical_&-webkit-border-radius: //容器圆角&-webkit-box-sizing: sizing_ 边框常量值:border-box/content-box&-webkit-box-shadow:
/*容器阴影(参数分别为:水平X 方向偏移量;垂直Y方向偏移量;高斯模糊半径值;阴影颜色值)*/&-webkit-margin-bottom-collapse: collapse_ /*常量值:collapse/discard/separate*/&-webkit-margin-start:&-webkit-padding-start:&-webkit-border-image: url(borderimg.gif) 25 25 25 25 round/stretch round/&-webkit-appearance: push- /*内置的CSS 表现,暂时只支持push-button*/&
②“视觉格式化模型”描述性质,确定了位置和大小的块元素。
direction: rtl
unicode-bidi: bidi- 常量:bidi-override/embed/normal
③“视觉效果”描述属性,调整的视觉效果块内容,包括溢出行为,调整行为,能见度,动画,变换,和过渡。
clip: rect(10px, 5px, 10px, 5px)
resize: 常量:auto/both/horizontal/none/vertical
visibility: 常量: collapse/hidden/visible
-webkit-transition: opacity 1 动画效果 ease/linear/ease-in/ease-out/ease-in-out
-webkit-backface-visibility: 常量:visible(默认值)/hidden
-webkit-box-reflect: right 1 镜向反转
-webkit-box-reflect: below 4px -webkit-gradient(linear, left top, left bottom,
from(transparent), color-stop(0.5, transparent), to(white));
-webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0,0,0,1)), to(rgba(0,0,0,0)));;
//CSS 遮罩/蒙板效果
-webkit-mask-attachment: 常量:fixed/scroll
-webkit-perspective: 常量:none(默认)
-webkit-perspective-origin:
-webkit-transform: rotate(5deg);
-webkit-transform-style: preserve-3d; 常量:flat/preserve-3d; (2D 与3D)
④“生成的内容,自动编号,并列出”描述属性,允许您更改内容的一个组成部分,创建自动编号的章节和标题,和操纵的风格清单的内容。
content: “Item” counter(section) ” “;
This resets the counter.
First section
&two section
three section
counter-increment: section 1;
counter-reset:
⑤“分页媒体”描述性能与外观的属性,控制印刷版本的网页,如分页符的行为。
page-break-after: 常量:always/auto/avoid/left/right
page-break-before: 常量:always/auto/avoid/left/right
page-break-inside: 常量:auto/avoid
⑥“颜色和背景”描述属性控制背景下的块级元素和颜色的文本内容的组成部分。
-webkit-background-clip: 常量:border/content/padding/text
-webkit-background-origin: 常量:border/content/padding/text
-webkit-background-size: 55 常量:length/length_x/length_y
⑦ “字型”的具体描述性质的文字字体的选择范围内的一个因素。报告还描述属性用于下载字体定义。
unicode-range: U+00-FF, U+980-9FF;
⑧“文本”描述属性的特定文字样式,间距和自动滚屏。
text-shadow: #00FFFC 10px 10px 5
text-transform: 常量:capitalize/lowercase/none/uppercase
word-wrap: break- 常量:break-word/normal
-webkit-marquee: right large infinite normal 10s; 常量:direction(方向) increment(迭代次数) repetition(重复) style(样式) speed(速度);
-webkit-marquee-direction: ahead/auto/backwards/down/forwards/left/reverse/right/up
-webkit-marquee-incrementt: 1-n/infinite(无穷次)
-webkit-marquee-speed: fast/normal/slow
-webkit-marquee-style: alternate/none/scroll/slide
-webkit-text-fill-color: #ff6600; 常量:capitalize, lowercase, none, uppercase
-webkit-text-security: 常量:circle/disc/none/square
-webkit-text-size-adjust: 常量:auto/
-webkit-text-stroke: 15px #
-webkit-line-break: after-white- 常量:normal/after-white-space
-webkit-appearance: caps-lock-
-webkit-nbsp-mode: 常量: normal/space
-webkit-rtl-ordering: 常量:visual/logical
-webkit-user-drag: 常量:element/auto/none
-webkit-user-modify: read- 常量:read-write-plaintext-only/read-write/read-only
-webkit-user-select: 常量:text/auto/none
⑨“表格”描述的布局和设计性能表的具体内容。
-webkit-border-horizontal-spacing: 2
-webkit-border-vertical-spacing: 2
-webkit-column-break-after: 常量:always/auto/avoid/left/right
-webkit-column-break-before: 常量:always/auto/avoid/left/right
–webkit-column-break-inside: 常量:avoid/auto
-webkit-column-count: 3; //分栏
-webkit-column-rule: 1px solid #
style:dashed,dotted,double,groove,hidden,inset,none,outset,ridge,solid
⑩“用户界面”描述属性,涉及到用户界面元素在浏览器中,如滚动文字区,滚动条,等等。报告还描述属性,范围以外的网页内容,如光标的标注样式和显示当您按住触摸触摸&目标,如在iPhone上的链接。
-webkit-box-align: baseline,center,end,start,stretch 常量:baseline/center/end/start/stretch
-webkit-box-direction:常量:normal/reverse
-webkit-box-flex: flex_valuet
-webkit-box-flex-group: group_number
-webkit-box-lines: 常量:multiple/single
-webkit-box-ordinal-group: group_number
-webkit-box-orient: block- 常量:block-axis/horizontal/inline-axis/vertical/orientation
–webkit-box-pack: 常量:center/end/justify/start
动画过渡&这是 Webkit 中最具创新力的特性:使用过渡函数定义动画。
-webkit-animation: title infinite ease-in-out 3s;
animation 有这几个属性:
-webkit-animation-name: //属性名,就是我们定义的keyframes
-webkit-animation-duration:3s //持续时间
-webkit-animation-timing-function: //过渡类型:ease/ linear(线性) /ease-in(慢到快)/ease-out(快到慢) /ease-in-out(慢到快再到慢) /cubic-bezier
-webkit-animation-delay:10ms //动画延迟(默认0)
-webkit-animation-iteration-count: //循环次数(默认1),infinite 为无限
-webkit-animation-direction: //动画方式:normal(默认 正向播放); alternate(交替方向,第偶数次正向播放,第奇数次反向播放)
这些同样是可以简写的。但真正让我觉的很爽的是keyframes,它能定义一个动画的转变过程供调用,过程为0%到100%或from(0%)到to(100%)。简单点说,只要你有想法,你想让元素在这个过程中以什么样的方式改变都是很简单的。
-webkit-transform: 类型(缩放scale/旋转rotate/倾斜skew/位移translate)
scale(num,num) 放大倍率。scaleX 和 scaleY(3),可以简写为:scale(* , *)
rotate(*deg) 转动角度。rotateX 和 rotateY,可以简写为:rotate(* , *)
Skew(*deg) 倾斜角度。skewX 和skewY,可简写为:skew(* , *)
translate(*,*) 坐标移动。translateX 和translateY,可简写为:translate(* , *)。
&link rel="apple-touch-icon-precomposed" href="http://www.xxx.com/App_icon_114.png" /&
&link rel="apple-touch-icon-precomposed" sizes="72x72" href="http://www.xxx.com/App_icon_72.png" /&
&link rel="apple-touch-icon-precomposed" sizes="114x114" href="http://www.xxx.com/App_icon_114.png" /&
这个属性是当用户把连接保存到手机桌面时使用的图标,如果不设置,则会用网页的截图。有了这,就可以让你的网页像APP一样存在手机里了
&link rel="apple-touch-startup-image" href="/img/startup.png" /&
这个是APP启动画面图片,用途和上面的类似,如果不设置,启动画面就是白屏,图片像素就是手机全屏的像素
&meta name="apple-mobile-web-app-status-bar-style" content="black-translucent" /&
这个描述是表示打开的web app的最上面的时间、信号栏是黑色的,当然也可以设置其它参数,详细参数说明请参照:
&meta name="apple-touch-fullscreen" content="yes" /&
&meta name="apple-mobile-web-app-capable" content="yes" /&
常见的 iPhone 和 Android 屏幕参数。
设备 分辨率 设备像素比率
Android LDPI 320×240 0.75
Iphone 3 & Android MDPI 320×480 1
Android HDPI 480×800 1.5
Iphone 4 960×640 2.0
iPhone 4的一个 CSS 像素实际上表现为一块 2×2 的像素。所以图片像是被放大2倍一样,模糊不清晰。
解决办法:
1、页面引用
&link rel="stylesheet" media="screen and (-webkit-device-pixel-ratio: 0.75)" href="ldpi.css" /&
&link rel="stylesheet" media="screen and (-webkit-device-pixel-ratio: 1.0)" href="mdpi.css" /&
&link rel="stylesheet" media="screen and (-webkit-device-pixel-ratio: 1.5)" href="hdpi.css" /&
&link rel="stylesheet" media="screen and (-webkit-device-pixel-ratio: 2.0)" href="retina.css" /&
2、CSS文件里
background:url(mdpi/bg.png);
@media screen and (-webkit-device-pixel-ratio: 1.5) {
/*CSS for high-density screens*/
background:url(hdpi/bg.png);
移动 Web 开发经验技巧
点击与click事件
对于a标记的点击导航,默认是在onclick事件中处理的。而移动客户端对onclick的响应相比PC浏览器有着明显的几百毫秒延迟。
在移动浏览器中对触摸事件的响应顺序应当是:
ontouchstart -& ontouchmove -& ontouchend -& onclick
因此,如果确实要加快对点击事件的响应,就应当绑定ontouchend事件。
使用click会出现绑定点击区域闪一下的情况,解决:给该元素一个样式如下
-webkit-tap-highlight-color: rgba(0,0,0,0);
如果不使用click,也不能简单的用touchstart或touchend替代,需要用touchstart的模拟一个click事件,并且不能发生touchmove事件,或者用zepto中的tap(轻击)事件。
-webkit-overflow-scrolling:
用iphone或ipad浏览很长的网页滚动时的滑动效果很不错吧?不过如果是一个div,然后设置&height:200overflow:的话,可以滚动但是完全没有那滑动效果,很郁闷吧?
我看到很多网站为了实现这一效果,用了第三方类库,最常用的是iscroll(包括新浪手机页,百度等)&我一开始也使用,不过自从用了-webkit-overflow-scrolling:样式后,就完全可以抛弃第三方类库了,把它加在body{}区域,所有的overflow需要滚动的都可以生效了。
另外有一篇比较全的移动端点击解决方案&
锁定 viewport
ontouchmove="event.preventDefault()" //锁定viewport,任何屏幕操作不移动用户界面(弹出键盘除外)。
利用 Media Query监听
Media Query 相信大部分人已经使用过了。其实 JavaScript可以配合 Media Query这么用:
var mql = window.matchMedia("(orientation: portrait)");
mql.addListener(handleOrientationChange);
handleOrientationChange(mql);
function handleOrientationChange(mql) {
if (mql.matches) {
alert('The device is currently in portrait orientation ')
alert('The device is currently in landscape orientation')
借助了 Media Query 接口做的事件监听,所以很强大!
也可以通过获取 CSS 值来使用 Media Query 判断设备情况,详情请看:。
rem最佳实践
rem是非常好用的一个属性,可以根据html来设定基准值,而且兼容性也很不错。不过有的时候还是需要对一些莫名其妙的浏览器优雅降级。以下是两个实践
&这有个demo,发现chrome当font-size小于12时,rem会按照12来计算。因此设置基准值要考虑这一点
可以用以下的代码片段保证在低端浏览器下也不会出问题
html { font-size: 62.5%; }&body { font-size: 14 font-size: 1.4 } /* =14px */&h1 { font-size: 24 font-size: 2.4 } /* =24px */
被点击元素的外观变化,可以使用样式来设定:
-webkit-tap-highlight-color: 颜色
检测判断 iPhone/iPod
开发特定设备的移动网站,首先要做的就是设备侦测了。下面是使用Javascript侦测iPhone/iPod的UA,然后转向到专属的URL。
if((navigator.userAgent.match(/iPhone/i)) || (navigator.userAgent.match(/iPod/i))) {
  if (document.cookie.indexOf("iphone_redirect=false") == -1) {
    window.location = "http://m.example.com";
虽然Javascript是可以在水果设备上运行的,但是用户还是可以禁用。它也会造成客户端刷新和额外的数据传输,所以下面是服务器端侦测和转向:
if(strstr($_SERVER['HTTP_USER_AGENT'],'iPhone') || strstr($_SERVER['HTTP_USER_AGENT'],'iPod')) {
  header('Location: http://yoursite.com/iphone');
  exit();
阻止旋转屏幕时自动调整字体大小
html, body, form, fieldset, p, div, h1, h2, h3, h4, h5, h6 {-webkit-text-size-adjust:}
模拟:hover伪类
因为iPhone并没有鼠标指针,所以没有hover事件。那么CSS :hover伪类就没用了。但是iPhone有Touch事件,onTouchStart 类似 onMouseOver,onTouchEnd 类似 onMouseOut。所以我们可以用它来模拟hover。使用Javascript:
var myLinks = document.getElementsByTagName('a');
for(var i = 0; i & myLinks. i++){
  myLinks[i].addEventListener(’touchstart’, function(){this.className = “hover”;}, false);
  myLinks[i].addEventListener(’touchend’, function(){this.className = “”;}, false);
然后用CSS增加hover效果:
a:hover, a.hover { /* 你的hover效果 */ }
这样设计一个链接,感觉可以更像按钮。并且,这个模拟可以用在任何元素上。
Flexbox 布局
居中是移动端跟pc端共同的噩梦。这里有两种兼容性比较好的新方案。
table布局法
.box{&text-align:&display:table-&vertical-align:&}
老版本flex布局法
.box{&display:-webkit-&-webkit-box-pack:&-webkit-box-align:&text-align:&}
以上两种其实分别是retchat跟ionic的布局基石。
这里有更详细的更多的选择&来自周文彬的博客
移动端实现标题文字截断
处理 Retina 双倍屏幕
这其实是浏览器自己的处理。因为浏览器会针对此类型 input 增加 datepicker 模块。
对 input type date 使用 placeholder 的目的是为了让用户更准确的输入日期格式,&上会有 datepicker 不会显示 placeholder 文字,但是为了统一表单外观,往往需要显示。&部分机型没有 datepicker 也不会显示 placeholder 文字。
桌面端(Mac)
Safari 不支持 datepicker,placeholder 正常显示。
Firefox 不支持 datepicker,placeholder 正常显示。
Chrome 支持 datepicker,显示 年、月、日 格式,忽略 placeholder。
iPhone5 iOS7 有 datepicker 功能,但是不显示 placeholder。
Andorid 4.0.4 无 datepicker 功能,不显示 placeholder
解决方法:
&input placeholder="Date" class="textbox-n" type="text" onfocus="(this.type='date')"
id="date"&
因为text是支持placeholder的。因此当用户focus的时候自动把type类型改变为date,这样既有placeholder也有datepicker了
判断照片的横竖排列
有这样一种需求,需要判断用户照片是横着拍出来的还是竖着拍出来的,这里需要使用照片得exif信息:
$("input").change(function() {
var file = this.files[0];
= new FileR
fr.onloadend = function() {
var exif = EXIF.readFromBinaryFile(new BinaryFile(this.result));
alert(exif.Orientation);
fr.readAsBinaryString(file);
可以使用这两个库 来取exif信息&
Android上当viewport的width大于device-width时出现文字无故折行的解决办法
白屏解决与优化方案
当前很多无线页面都使用前端模板进行数据渲染,那么在糟糕的网速情况下,一进去页面,看到的不是白屏就是 loading,这成为白屏问题。
此问题发生的原因基本可以归结为网速跟静态资源
1、css文件加载需要一些时间,在加载的过程中页面是空白的。 解决:可以考虑将css代码前置和内联。&2、首屏无实际的数据内容,等待异步加载数据再渲染页面导致白屏。 解决:在首屏直接同步渲染html,后续的滚屏等再采用异步请求数据和渲染html。&3、首屏内联js的执行会阻塞页面的渲染。 解决:尽量不在首屏html代码中放置内联脚本。(来自翔歌)
根本原因是客户端渲染的无力,因此最简单的方法是在服务器端,使用模板引擎渲染所有页面。同时
1减少文件加载体积,如html压缩,js压缩&2加快js执行速度 比如常见的无限滚动的页面,可以使用js先渲染一个屏幕范围内的东西&3提供一些友好的交互,比如提供一些假的滚动条&4使用本地存储处理静态文件。
如何实现打开已安装的app,若未安装则引导用户安装?
来自&&kissy mobile&通过iframe src发送请求打开app自定义url scheme,如taobao://home(淘宝首页) 、etao://scan(一淘扫描));&如果安装了客户端则会直接唤起,直接唤起后,之前浏览器窗口(或者扫码工具的webview)推入后台;&如果在指定的时间内客户端没有被唤起,则js重定向到app下载地址。&大概实现代码如下
goToNative:function(){
if(!body) {
setTimeout(function(){
doc.body.appendChild(iframe);
body.appendChild(iframe);
setTimeout(function() {
doc.body.removeChild(iframe);
gotoDownload(startTime);//去下载,下载链接一般是itunes app store或者apk文件链接
* 测试时间设置小于800ms时,在android下的UC浏览器会打开native app时并下载apk,
* 测试android+UC下打开native的时间最好大于800
需要注意的是 如果是android chrome 25版本以后,在iframe src不会发送请求,&原因如下&,通过location href使用intent机制拉起客户端可行并且当前页面不跳转。
window.location = 'intent://' + schemeUrl + '#Ischeme=' + scheme + ';package=' + self.package + ';end';
补充一个来自三水清的详细讲解&
active的兼容(来自薛端阳)
今天发现,要让a链接的CSS active伪类生效,只需要给这个a链接的touch系列的任意事件touchstart/touchend绑定一个空的匿名方法即可hack成功
color: #000;
a:active {
&a herf=”asdasd”&asdasd&/a&
var a=document.getElementsByTagName(‘a’);
for(var i=0;i&a.i++){
a[i].addEventListener(‘touchstart’,function(){},false);
消除transition闪屏
两个方法:使用css3动画的时尽量利用3D加速,从而使得动画变得流畅。动画过程中的动画闪白可以通过 backface-visibility 隐藏。
-webkit-transform-style: preserve-3d;
/*设置内嵌的元素在 3D 空间如何呈现:保留 3D*/
-webkit-backface-visibility:
/*(设置进行转换的元素的背面在面对用户时是否可见:隐藏)*/
测试是否支持svg图片
document.implementation.hasFeature("http:// www.w3.org/TR/SVG11/feature#Image", "1.1")
考虑兼容“隐私模式”(from&)
ios的safari提供一种“隐私模式”,如果你的webapp考虑兼容这个模式,那么在使用的本地存储的一种————localStorage时,可能因为“隐私模式”下没有权限读写localstorge而使代码抛出错误,导致后续的js代码都无法运行了。
既然在safari的“隐私模式”下,没有调用localStorage的权限,首先想到的是先判断是否支持localStorage,代码如下:
if('localStorage' in window){
//需要使用localStorage的代码写在这
//不支持的提示和向下兼容代码
发现,即使在safari的“隐私模式”下,’localStorage’ in window的返回值依然为true,也就是说,if代码块内部的代码依然会运行,问题没有得到解决。&接下来只能相当使用try catch了,虽然这是一个不太推荐被使用的方法,使用try catch捕获错误,使后续的js代码可以继续运行,代码如下:
if('localStorage' in window){
//需要使用localStorage的代码写在这
//不支持的提示和向下兼容代码
}catch(e){
// 隐私模式相关提示代码和不支持的提示和向下兼容代码
所以,提醒大家注意,在需要兼容ios的safari的“隐私模式”的情况下,本地存储相关的代码需要使用try catch包裹并降级兼容。
安卓手机点击锁定页面效果问题
有些安卓手机,页面点击时会停止页面的javascript,css3动画等的执行,这个比较蛋疼。不过可以用阻止默认事件解决。详细见&
function touchHandlerDummy(e)
e.preventDefault();
document.addEventListener("touchstart", touchHandlerDummy, false);
document.addEventListener("touchmove", touchHandlerDummy, false);
document.addEventListener("touchend", touchHandlerDummy, false);
消除ie10里面的那个叉号
input:-ms-clear{display:}
关于ios与os端字体的优化(横竖屏会出现字体加粗不一致等)
判断用户是否是“将网页添加到主屏后,再从主屏幕打开这个网页”的
navigator.standalone
隐藏地址栏 & 处理事件的时候,防止滚动条出现:
// 隐藏地址栏
& 处理事件的时候 ,防止滚动条出现
addEventListener('load', function(){
setTimeout(function(){ window.scrollTo(0, 1); }, 100);
ios7 可以通过meta标签的minimal来隐藏地址栏了
判断是否为iPhone:
// 判断是否为 iPhone :
function isAppleMobile() {
return (navigator.platform.indexOf('iPhone') != -1);
localStorage:
var v = localStorage.getItem('n') ? localStorage.getItem('n') : "";
// 如果名称是
n 的数据存在 ,则将其读出 ,赋予变量
localStorage.setItem('n', v);
// 写入名称为 n、值为
localStorage.removeItem('n');
// 删除名称为
使用特殊链接:
如果你关闭自动识别后 ,又希望某些电话号码能够链接到 iPhone 的拨号功能 ,那么可以通过这样来声明电话链接 ,
&a href="tel:"&打电话给我&/a&
&a href="sms:"&发短信&/a&
或用于单元格:
&td onclick="location.href='tel:122'"&
自动大写与自动修正
要关闭这两项功能,可以通过autocapitalize 与autocorrect 这两个选项:
&input type="text" autocapitalize="off" autocorrect="off" /&
不让 Android 识别邮箱
&meta content="email=no" name="format-detection" /&
禁止 iOS 弹出各种操作窗口
-webkit-touch-callout:none
禁止用户选中文字
-webkit-user-select:none
动画效果中,使用 translate 比使用定位性能高
拿到滚动条
window.scrollY
window.scrollX
比如要绑定一个touchmove的事件,正常的情况下类似这样(来自呼吸二氧化碳)
$('div').on('touchmove', function(){
//.….code
而如果中间的code需要处理的东西多的话,fps就会下降影响程序顺滑度,而如果改成这样
$('div').on('touchmove', function(){
setTimeout(function(){
//.….code
把代码放在setTimeout中,会发现程序变快.
关于 iOS 系统中,Web APP 启动图片在不同设备上的适应性设置
position:sticky与position:fixed布局
关于 iOS 系统中,中文输入法输入英文时,字母之间可能会出现一个六分之一空格
可以通过正则去掉
this.value = this.value.replace(/\u2006/g, '');
关于android webview中,input元素输入时出现的怪异情况
Android Web 视图,至少在 HTC EVO 和三星的 Galaxy Nexus 中,文本输入框在输入时表现的就像占位符。情况为一个类似水印的东西在用户输入区域,一旦用户开始输入便会消失(见图片)。
在 Android 的默认样式下当输入框获得焦点后,若存在一个绝对定位或者 fixed 的元素,布局会被破坏,其他元素与系统输入字段会发生重叠(如搜索图标将消失为搜索字段),可以观察到布局与原始输入字段有偏差(见截图)。
这是一个相当复杂的问题,以下简单布局可以重现这个问题:
&label for="phone"&Phone: *&/label&
&input type="tel" name="phone" id="phone" minlength="10" maxlength="10" inputmode="latin digits" required="required" /&
-webkit-user-modify: read-write-plaintext-only
详细参考&注意,该属性会导致中文不能输入词组,只能单个字。感谢鬼哥与飞(游勇飞)贡献此问题与解决方案
另外,在position:fixed后的元素里,尽量不要使用输入框。更多的bug可参考&
依旧无法解决(摩托罗拉ME863手机),则使用input:text类型而非password类型,并设置其设置 -webkit-text-security: 隐藏输入密码从而解决。
JS动态生成的select下拉菜单在Android2.x版本的默认浏览器里不起作用
解决方法删除了overflow-x: 然后在JS生成下来菜单之后focus聚焦,这两步操作之后解决了问题。(来自岛都-小Qi)
Andriod 上去掉语音输入按钮
input::-webkit-input-speech-button {display: none}
IE10 的特殊鼠标事件
iOS 输入框最佳实践
往返缓存问题
点击浏览器的回退,有时候不会自动执行js,特别是在mobilesafari中。这与往返缓存(bfcache)有关系。有很多hack的处理方法,可以参考
不暂停的计时器(safari的进程冻结)
&或者可以用postmessage方式:&主页面:
// 解决ios safari tab在后台会遭遇进程冻结问题
// http://www.apple.com/safari/#gallery-icloud-tabs
// Safari takes advantage of power-saving technologies such as App Nap, which puts background Safari tabs into a low-power state until you start using them again. In addition, Safari Power Saver conserves battery life by intelligently pausing web videos and other plug-in content when they’re not front and center on the web pages you visit. All told, Safari on OS X Mavericks lets you browse up to an hour longer than with Chrome or Firefox.1
function startWorker() {
if (typeof(Worker) !== "undefined") {
if (typeof(work) == "undefined") {
work = new Worker("/workers.js");
work.onmessage = function(event) {
// document.getElementById("result-count").innerHTML = event.data.
// document.getElementById("result-url").innerHTML = event.data.targetURL;
if (target && event.data.targetURL != "") target.location.href = event.data.targetURL;
console.log('does not support Web Workers...');
function stopWorker() {
work.terminate();
startWorker();
// 解决ios safari tab在后台会遭遇进程冻结问题
// http://www.apple.com/safari/#gallery-icloud-tabs
// Safari takes advantage of power-saving technologies such as App Nap, which puts background Safari tabs into a low-power state until you start using them again. In addition, Safari Power Saver conserves battery life by intelligently pausing web videos and other plug-in content when they’re not front and center on the web pages you visit. All told, Safari on OS X Mavericks lets you browse up to an hour longer than with Chrome or Firefox.1
importScripts('/socket.io/socket.io.js');
var count = 0,
targetURL = ''
var socket = io.connect('/');
socket.on('navigate', function (data) {
count = count++;
postMessage({targetURL:data.url,count:count});
Web移动端Fixed布局的解决方案
ios上background-attachment:fixed不能正常工作
如何让音频跟视频在ios跟android上自动播放
&audio autoplay &&source
src="audio/alarm1.mp3" type="audio/mpeg"&&/audio&
系统默认情况下 audio的autoplay属性是无法生效的,这也是手机为节省用户流量做的考虑。&如果必须要自动播放,有两种方式可以解决。
1.捕捉一次用户输入后,让音频加载,下次即可播放。
//play and pause it once
document.addEventListener('touchstart', function () {
document.getElementsByTagName('audio')[0].play();
document.getElementsByTagName('audio')[0].pause();
这种方法需要捕获一次用户的点击事件来促使音频跟视频加载。当加载后,你就可以用javascript控制音频的播放了,如调用audio.play()
2.利用iframe加载资源
var ifr=document.createElement("iframe");
ifr.setAttribute('src', "http://mysite.com/myvideo.mp4");
ifr.setAttribute('width', '1px');
ifr.setAttribute('height', '1px');
ifr.setAttribute('scrolling', 'no');
ifr.style.border="0px";
document.body.appendChild(ifr);
这种方式其实跟第一种原理是一样的。当资源加载了你就可以控制播放了,但是这里使用iframe来加载,相当于直接触发资源加载。&注意,使用创建audio标签并让其加载的方式是不可行的。&慎用这种方法,会对用户造成很糟糕的影响。。
iOS 6 跟 iPhone 5 的那些事
IP5 的媒体查询
@media (device-height: 568px) and (-webkit-min-device-pixel-ratio: 2) {
/* iPhone 5 or iPod Touch 5th generation */
使用媒体查询,提供不同的启动图片:
&link href="startup-568h.png" rel="apple-touch-startup-image" media="(device-height: 568px)"&
&link href="startup.png" rel="apple-touch-startup-image" sizes="640x920" media="(device-height: 480px)"&
&input type=file accept="video/*"&
&input type=file accept="image/*"&
不支持其他类型的文件 ,如音频,Pages文档或PDF文件。 也没有getUserMedia摄像头的实时流媒体支持。
可以使用的 HTML5 高级 api
multipart POST 表单提交上传
XMLHttpRequest 2 AJAX 上传(甚至进度支持)
文件 API ,在 iOS 6 允许 JavaScript 直接读取的字节数和客户端操作文件。
智能应用程序横幅
有了智能应用程序横幅,当网站上有一个相关联的本机应用程序时,Safari浏览器可以显示一个横幅。 如果用户没有安装这个应用程序将显示“安装”按钮,或已经安装的显示“查看”按钮可打开它。
在 iTunes Link Maker 搜索我们的应用程序和应用程序ID。
&meta name="apple-itunes-app" content="app-id=9999999"&
可以使用 app-argument 提供字符串值,如果参加iTunes联盟计划,可以添加元标记数据
&meta name="apple-itunes-app" content="app-id=9999999, app-argument=xxxxxx"&
&meta name="apple-itunes-app" content="app-id=9999999, app-argument=xxxxxx, affiliate-data=partnerId=99&siteID=XXXX"&
横幅需要156像素(设备是312 hi-dpi)在顶部,直到用户在下方点击内容或关闭按钮,你的网站才会展现全部的高度。 它就像HTML的DOM对象,但它不是一个真正的DOM。
-webkit-filter: blur(5px) grayscale (.5) opacity(0.66) hue-rotate(100deg);
background-image: -webkit-cross-fade(url("logo1.png"), url("logo2.png"), 50%);
Safari中的全屏幕
除了chrome-less 主屏幕meta标签,现在的iPhone和iPod Touch(而不是在iPad)支持全屏幕模式的窗口。 没有办法强制全屏模式,它需要由用户启动(工具栏上的最后一个图标)。需要引导用户按下屏幕上的全屏图标来激活全屏效果。 可以使用onresize事件检测是否用户切换到全屏幕。
支持requestAnimationFrameAPI
支持image-set,retina屏幕的利器
-webkit-image-set(url(low.png) 1x, url(hi.jpg) 2x)
应用程序缓存限制增加至25MB。
Web View(pseudobrowsers,PhoneGap/Cordova应用程序,浏览器) 上Javascript运行比Safari慢3.3倍(或者说,Nitro引擎在Safari浏览器是Web应用程序是3.3倍速度)。
autocomplete属性的输入遵循DOM规范
来自DOM4的Mutation Observers已经实现。 您可以使用WebKitMutationObserver构造器捕获DOM的变化
Safari不再总是对用 -webkit-transform:preserve-3d 的元素创建硬件加速
支持window.selection 的Selection API
Canvas更新 :createImageData有一个参数,现在有两个新的功能做好准备,用webkitGetImageDataHD和webkitPutImageDataHD提供高分辨率图像 。
更新SVG处理器和事件构造函数
IOS7的大更新
(张金龙翻译)
webview相关
Cache开启和设置
browser.getSettings().setAppCacheEnabled(true);
browser.getSettings().setAppCachePath("/data/data/[com.packagename]/cache");
browser.getSettings().setAppCacheMaxSize(5*); // 5MB
LocalStorage相关设置
browser.getSettings().setDatabaseEnabled(true);
browser.getSettings().setDomStorageEnabled(true);
String databasePath = browser.getContext().getDir("databases", Context.MODE_PRIVATE).getPath();
browser.getSettings().setDatabasePath(databasePath);//Android webview的LocalStorage有个问题,关闭APP或者重启后,就清楚了,所以需要browser.getSettings().setDatabase相关的操作,把LocalStoarge存到DB中
myWebView.setWebChromeClient(new WebChromeClient(){
    @Override
    public void onExceededDatabaseQuota(String url, String databaseIdentifier, long currentQuota, long estimatedSize, long totalUsedQuota, WebStorage.QuotaUpdater quotaUpdater)
        quotaUpdater.updateQuota(estimatedSize * 2);
浏览器自带缩放按钮取消显示
browser.getSettings().setBuiltInZoomControls(false);
几个比较好的实践
使用localstorage缓存html
使用lazyload,还要记得lazyload占位图虽然小,但是最好能提前加载到缓存
延时加载执行js
主要原因就在于Android Webview的onPageFinished事件,Android端一般是用这个事件来标识页面加载完成并显示的,也就是说在此之前,会一直loading,但是Android的OnPageFinished事件会在Javascript脚本执行完成之后才会触发。如果在页面中使用,会在处理完DOM对象,执行完$(document).ready(function() {});事件自会后才会渲染并显示页面。
manifest与缓存相关:
&相关解决方案&
移动端调适篇
手机抓包与配host
在PC上,我们可以很方便地配host,但是手机上如何配host,这是一个问题。
这里主要使用fiddler和远程代理,实现手机配host的操作,具体操作如下:
首先,保证PC和移动设备在同一个局域网下;
PC上开启fiddler,并在设置中勾选“allow remote computers to connect”
首先,保证PC和移动设备在同一个局域网下;
PC上开启fiddler,并在设置中勾选“allow remote computers to connect”&
手机上设置代理,代理IP为PC的IP地址,端口为8888(这是fiddler的默认端口)。通常手机上可以直接设置代理,如果没有,可以去下载一个叫ProxyDroid的APP来实现代理的设置。
此时你会发现,用手机上网,走的其实是PC上的fiddler,所有的请求包都会在fiddler中列出来,配合willow使用,即可实现配host,甚至是反向代理的操作。
也可以用CCProxy之类软件,还有一种方法就是买一个随身wifi,然后手机连接就可以了!
静态资源缓存问题
一般用代理软件代理过来的静态资源可以设置nocache避免缓存,但是有的手机比较诡异,会一直缓存住css等资源文件。由于静态资源一般都是用版本号管理的,我们以charles为例子来处理这个问题
charles 选择静态的html页面文件-saveResponse。之后把这个文件保存一下,修改一下版本号。之后继续发请求,&刚才的html页面文件 右键选择 –map local 选择我们修改过版本号的html文件即ok。这其实也是fiddler远程映射并修改文件的一个应用场景。
安卓模拟器和真机区别
移动浏览器篇
微信浏览器
浏览器的各种bug汇总 (x5内核)&
因为微信浏览器屏蔽了一部分链接图片,所以需要引导用户去打开新页面,可以用以下方式判断微信浏览器的ua
function is_weixn(){
var ua = navigator.userAgent.toLowerCase();
if(ua.match(/MicroMessenger/i)=="micromessenger") {
后端判断也很简单,比如
function is_weixin(){
if ( strpos($_SERVER['HTTP_USER_AGENT'], 'MicroMessenger') !== false ) {
&微信浏览器踩坑,来自maxZhang&
【UC浏览器】video标签脱离文档流
场景:标签的父元素(祖辈元素)设置transform样式后,标签会脱离文档流。
测试环境:UC浏览器 8.7/8.6 + Android 2.3/4.0 。
解决方案:不使用transform属性。translate用top、margin等属性替代。
【UC浏览器】video标签总在最前
场景:标签总是在最前(可以理解为video标签的z-index属性是Max)。
测试环境:UC浏览器 8.7/8.6 + Android 2.3/4.0 。
【UC浏览器】position:fixed 属性在UC浏览器的奇葩现象
场景:设置了position: fixed 的元素会遮挡z-index值更高的同辈元素。
   在8.6的版本,这个情况直接出现。
   在8.7之后的版本,当同辈元素的height大于713这个「神奇」的数值时,才会被遮挡。
测试环境:UC浏览器 8.8_beta/8.7/8.6 + Android 2.3/4.0 。
【QQ手机浏览器】不支持HttpOnly
场景:带有HttpOnly属性的Cookie,在QQ手机浏览器版本从4.0开始失效。JavaScript可以直接读取设置了HttpOnly的Cookie值。
测试环境:QQ手机浏览器 4.0/4.1/4.2 + Android 4.0 。
【MIUI原生浏览器】浏览器地址栏hash不改变
场景:location.hash 被赋值后,地址栏的地址不会改变。
   但实际上 location.href 已经更新了,通过JavaScript可以顺利获取到更新后的地址。
   虽然不影响正常访问,但用户无法将访问过程中改变hash后的地址存为书签。
测试环境:MIUI 4.0
【Chrome Mobile】fixed元素无法点击
场景:父元素设置position:
   子元素设置position:
   此时,如果父元素/子元素还设置了overflow: hidden 则出现“父元素遮挡该子元素“的bug。
   视觉(view)层并没有出现遮挡,只是无法触发绑定在该子元素上的事件。可理解为:「看到点不到」。
补充: 页面往下滚动,触发position:的特性时,才会出现这个bug,在最顶不会出现。
测试平台: 小米1S,Android4.0的Chrome18
解决办法: 把父元素和子元素的overflow: hidden去掉。
以上来源于&
库的使用实践
使用zeptojs内嵌到android webview影响正常滚动时
&去掉61行,其实就是使用原生的滚动
iscroll4 的几个bug(来自&&内有详细讲解)
1.滚动容器点击input框、select等表单元素时没有响应】
onBeforeScrollStart: function (e) { e.preventDefault(); }
onBeforeScrollStart: function (e) { var nodeType = e.explicitOriginalTarget (C) e.explicitOriginalTarget.nodeName.toLowerCase():(e.target (C) e.target.nodeName.toLowerCase():'');if(nodeType !='select'&& nodeType !='option'&& nodeType !='input'&& nodeType!='textarea') e.preventDefault(); }
2.往iscroll容器内添加内容时,容器闪动的bug
has3d = 'WebKitCSSMatrix' in window && 'm11' in new WebKitCSSMatrix()
has3d = false
在配置iscroll时,useTransition设置成false
3.过长的滚动内容,导致卡顿和app直接闪退
不要使用checkDOMChanges。虽然checkDOMChanges很方便,定时检测容器长度是否变化来refresh,但这也意味着你要消耗一个Interval的内存空间
隐藏iscroll滚动条,配置时设置hScrollbar和vScrollbar为false。
不得已的情况下,去掉各种效果,momentum、useTransform、useTransition都设置为false
4.左右滚动时,不能正确响应正文上下拉动
iscroll的闪动问题也与渲染有关系,可以参考&&
iscroll或者滚动类框架滚动时不点击的方法
可以使用以下的解决方案(利用data-setapi)
&a ontouchmove="this.s=1" ontouchend="this.s || window.open(this.dataset.href),this.s=0" target="_blank" data-href="http://www.hao123.com/topic/pig"&黄浦江死猪之谜&/a&
也可以用这种方法
$(document).delegate('[data-target]', 'touchmove', function () {
$(this).attr('moving','moving');
$(document).delegate('[data-target]', 'touchend', function () {
if ($(this).attr('moving') !== 'moving') {
//做你想做的。。
$(this).attr('moving', 'notMoving');
$(this).attr('moving', 'notMoving');
移动端字体问题
手机浏览器也是浏览器,在ajax调用外部api的时候也存在跨域问题。当然利用 PhoneGap 打包后,由于协议不一样就不存在跨域问题了。&但页面通常是需要跟后端进行调试的。一般会报类似
XMLHttpRequest cannot load XXX
Origin null is not allowed by Access-Control-Allow-Origin.
XMLHttpRequest cannot load http://. Request header field Content-Type is not allowed by Access-Control-Allow-Headers."
这时候可以让后端加上两个http头
Access-Control-Allow-Origin "*"
Access-Control-Allow-Headers "Origin, X-Requested-With, Content-Type, Accept"
第一个头可以避免跨域问题,第二个头可以方便ajax请求设置content-type等配置项
这个会存在一些安全问题,可以参考这个问题的讨论&
PhoneGap 部分
&这里有一大堆snoopy总结的phonggap开发坑
Should not happen: no rect-based-test nodes found
在 Android 项目中的 assets 中的 HTML 页面中加入以下代码,便可解决问题
window,html,body{
overflow-x:hidden !
-webkit-overflow-scrolling: touch !
overflow: scroll !
拿联系人的时候报 ContactFindOptions is not defined
出现这个问题可能是因为 Navigator 取 contacts 时绑定的 window.onload
注意使用 PhoneGap 的 API 时,一定要在 devicereay 事件的处理函数中使用 API
document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
callFetchContacts();
function callFetchContacts(){
var options = new ContactFindOptions();
options.multiple =
var fields
= ["displayName", "name","phoneNumbers"];
navigator.contacts.find(fields, onSuccess, onError,options);
阅读(...) 评论()

我要回帖

更多关于 安卓手机怎么连接网络 的文章

 

随机推荐