在实际开发上先的h5页面产品中,总会遇到各种坑,好多坑都是安卓和iPhone端兼容的问题(用电脑谷歌浏览器输入  chrome://inspect/#devices可以用手机USB调试,打开)

eg:

  1. 软键盘弹出时会影响到的页面布局
  2. 如果在iframe中用到透明罩,想用fixed却失效?
  3. angular中如果用$scope控制布尔值来添加/删除类时,获取这个节点的坑
  4. 在获取用户头像等信息在canvas画图时加载的顺序

暂时遇到的问题,比较磨人一点(之后遇到会慢慢补充)

  1. 对于h5页面产品,输入框弹出软键盘,页面布局可能会压缩(安卓手机存在,苹果无这bug),我用的单位是vh,所以会出现这个令人头疼的bug,知道了这个原因,先对万恶的安卓系统吐槽一遍,然后将高度的单位全部用vw替换,因为宽度不会变啊,调试一遍,跑一下页面,问题解决.

  2.很多公司都喜欢开发的页面使用iframe,所以也引发了很多的问题,就比如说你想用吸顶条或者一个透明遮罩层的时候,习惯了想用position:fixed的我,用了fixed失效,狠狠的对公司使用这个iframe吐槽一遍,但是也只能老老实实的想其他办法去解决,想过利用js去控制高度等等处理办法,最傻的是用绝对定位,高度100%,然后安卓和苹果总有一个会出现问题,真是内心吐槽一万遍,这两个系统就是爱搞特殊化,而且是手指向上拖动手机屏幕时,遮罩层也跟着跑,扎心!!!

这个时候,灵光乍现的我想到了一个绝佳的办法,那就是js控制获取手机屏幕高度,用哪个方法呢?毕竟有好多,诸位别慌,且跟着往下看:

  1. 网页可见区域高:document.body.clientHeight
  2. 网页可见区域宽:document.body.clientWidth
  3. 网页可见区域宽:document.body.offsetWidth (包括边线的宽)
  4. 网页可见区域高:document.body.offsetHeight (包括边线的宽)
  5. 网页正文全文宽:document.body.scrollWidth
  6. 网页正文全文高:document.body.scrollHeight
  7. 网页被卷去的高:document.body.scrollTop
  8. 网页被卷去的左:document.body.scrollLeft
  9. 网页正文部分上:window.screenTop
  10. 网页正文部分左:window.screenLeft
  11. 屏幕分辨率的高:window.screen.height
  12. 屏幕分辨率的宽:window.screen.width
  13. 屏幕可用工作区高度:window.screen.availHeight
  14. 屏幕可用工作区宽度:window.screen.availWidth

  看到这么多,你也许会想问我,这么多,都可以吗?那我偷偷的告诉你,你可不要告诉别人哦,用前面的12种方法获取到的你总会发现不是安卓闹小脾气就是ios要逗你玩,这个时候,你要掌握游戏的规则,不要被它所主导你的思维,我也就不墨迹了,这时候,你应该选用   13/14   屏幕的可用工作区宽高,这个算是都兼容

  1. HTML:
    <!-- you are jackpot -->
  2. <div class="{{ isJackpot ? 'yJackpot' : 'nJackpot' }}" style="">
  3. <div class="closeJackpot" ng-click="isJackpot = !isJackpot;">&times;</div>
  4. </div>
  1. CSS:
  2.  
  3. .yJackpot{
  4. transition: all linear 0.5s;
  5. -webkit-transition: all linear 0.5s;
  6. width: 100%;
  7. position: absolute;
  8. top: 0;
  9. left: 0;
  10. z-index: 99;
  11. background: url(../images/prize.png) center no-repeat;
  12. background-size: 100% 100%;
  13. }
  14. .nJackpot{
  15. position: absolute;
  16. top: 0;
  17. left: 0;
  18. transition: all linear 0.5s;
  19. -webkit-transition: all linear 0.5s;
  20. background: url(../images/prize.png) center no-repeat;
  21. background-size: 100% 100%;
  22. z-index: 99;
  23. width: 0;
  24. height: 0;
  25. }
  1. (Angular1)js:
  2.  
  3. $scope.isJackpot = true; //
  4. setTimeout(function(){
  5.   console.log(window.screen.availHeight)
  6.   document.querySelector(".yJackpot").style.height = window.screen.availHeight + "px";
  7.   document.querySelector(".yJackpot").addEventListener('touchmove',function(e){
  8.     e.preventDefault();
  9.   },false)
  10. },100)

  上述js中你可能注意到我加了一个延时器,你们可能有点疑惑,好吧,这个问题就要和我的问题3挂钩了,怎么说呢,这就是dom加载和js加载先后的问题了,这也算开发中遇到的一个小坑,我很巧妙地加了一个延时,也许有更好的解决办法,只是我暂时还没发现,你们可以评论对我指教(龙在这里不胜感激,因为这是开发接触ng1,还没系统的学过ng1)

  而之后的事件监听则是为了实现禁止用户拖动,哈哈,这个方法一瞬间出现在我脑海,瞬间敲出来测试,完美实现.只能说,有些东西还是得熟悉,才能在开发中活学活用

  4.接下来要说的就是,获取用户头像之后,在画布上画图出现的问题了,这个比较恶心人,不对,是比较绕,容我小小的吐槽一次~

  1. angular
  2. .module('name')
  3. .factory('myService', myService)
  4.  
  5. function myService($http, $q,$httpParamSerializerJQLike) {
  6. return {
  7. getUserNicknameMyID: getUserNicknameMyID,
  8. getWXShare: getWXShare,
  9. socialLogin: socialLogin
  10. };
  11.   //获取用户信息
  12. function getUserNicknameMyID(myId) {
  13. var params = {};
  14. params.myId= myId;
  15. return $http.get(ENDPOINT + 'getUserNickname', {
  16. params: params
  17. })
  18. .then(getUserNicknameComplete)
  19. .catch(getUserNicknameFailed);
  20.  
  21. function getUserNicknameComplete(response) {
  22. return response.data;
  23. }
  24.  
  25. function getUserNicknameFailed(response) {
  26. return $q.reject(response.data);
  27. }
  28. }
  29.   //微信分享
  30. function getWXShare() {
  31. var params = {};
  32. params.url = location.href;
  33. params.appid = 'appid';
  34.  
  35. return $http.get('此处为链接', { params: params })
  36. .then(getWXShareComplete)
  37. .catch(getWXShareFailed);
  38.  
  39. function getWXShareComplete(response) {
  40. return response.data;
  41. }
  42.  
  43. function getWXShareFailed(response) {
  44. return $q.reject(response.data);
  45. }
  46.  
  47. }
  48.   
  49. function socialLogin(code) {
  50. var params = {};
  51. params.code = code;
  52. params.base = "base";
  53. params.platform = 0;
  54. return $http({
  55. method: 'POST',
  56. url: ENDPOINT + 'socialLogin',
  57. headers: {
  58. 'Content-Type': 'application/x-www-form-urlencoded'
  59. },
  60. data: $httpParamSerializerJQLike(params)
  61. }).then(postSocialLoginComplete)
  62. .
  63. catch(postSocialLoginFailed);
  64.  
  65. function postSocialLoginComplete(response) {
  66. return response.data;
  67. }
  68.  
  69. function postSocialLoginFailed(response) {
  70. return $q.reject(response.data);
  71. }
  72. }
  73. }

  以上我在factory中封装的请求方式,但是它是异步请求,所以你不知道你的用户信息在什么阶段获取到这个头像,然后去绘制,我就很傻了,先把所有的绘制完成再去绘制这个头像,问题就出来了,头像要么不绘制,要么就是给你绘制,随意的很,怎么办,只能收拾他,把之前所有的绘制方法各自封装成一个函数,然后一层一层的往下调用,上一步完成才往下走,将头像方法仍在了第一步,再次测试,发现完美解决,心里感觉舒服多了~

当然还有遇到的问题,估计大家使用过h5产品绘图的可能都知道,canvas并不能直接保存在手机,那怎么办呢,调用插件Canvas2Image.js,然后将其封装成一个函数,每次绘制之后都将其调用绘制在指定的img上面,并将img覆盖在canvas上面,实现以假乱真的效果....具体代码如下:

  1. function createImg(canvas) { //在id为img元素内生成图片
  2. var img = document.getElementById("img");
  3. if(!img.hasChildNodes()) {
  4. img.appendChild(Canvas2Image.convertToImage(canvas, 750, 1180, "png"));
  5. } else {
  6. img.removeChild(img.childNodes[0]);
  7. img.appendChild(Canvas2Image.convertToImage(canvas, 750, 1180, "png"));
  8. }
  9. }

  好了,写了这么多,也有点困了,看看时间,已经是深夜23:46  记录于2018/03/08

  明天会更好~~

h5开发中,利用微信或者QQ登陆以后获取用户头像在canvas画布显示问题的更多相关文章

  1. 微信测试号开发之九 微信网页授权:页面获取用户openid

    原文链接:https://blog.csdn.net/qq_37936542/article/details/78981369 一:配置接口 注意:这里填写的是域名(是一个字符串),而不是URL,因此 ...

  2. [小程序]微信小程序登陆并获取用户信息

    1.小程序js端调用框架登陆API,获取到一个临时code,拿着这个code去调用自己的服务端接口 2.在自己的服务器端,使用app_id app_secrect code可以获取到用户的openid ...

  3. H5开发中的问题总结

    最近公司做了一个出行日记的项目,里面的页面十多页,天天加班,做到吐血.总体来说,写页面的时候虽然是十多个页面,其实难度还是在每个页面的特效上.公司是易到用车,出行日记的页面在APP里有生成入口,有兴趣 ...

  4. H5开发中的故障

    本篇博文会不断的收录我在做H5页面时遇到的问题以及解决方案,当然有的问题,我也没有遇到好的解决方案,所以如果你有解决的办法,请务必不吝赐教! H5开发中的故障       微信APP返回按钮不刷新页面 ...

  5. 如需在APP中使用腾讯QQ登陆,需提前申请获取腾讯QQ的APPKEY和APPSecret。

    如需在APP中使用腾讯QQ登陆,需提前申请获取腾讯QQ的APPKEY和APPSecret. 申请流程如下: 步骤1:登陆腾讯开放平台.链接地址: http://open.qq.com/ . 步骤2:填 ...

  6. vue开发中利用正则限制input框的输入(手机号、非0开头的正整数等)

    我们在前端开发中经常会碰到类似手机号输入获取验证码的情况,通常情况下手机号的输入需要只能输入11位的整数数字.并且需要过滤掉一些明显不符合手机号格式的输入,那么我们就需要用户在输入的时候就控制可以输入 ...

  7. 第八篇 :微信公众平台开发实战Java版之如何网页授权获取用户基本信息

    第一部分:微信授权获取基本信息的介绍 我们首先来看看官方的文档怎么说: 如果用户在微信客户端中访问第三方网页,公众号可以通过微信网页授权机制,来获取用户基本信息,进而实现业务逻辑. 关于网页授权回调域 ...

  8. php 实现微信模拟登陆、获取用户列表及群发消息功能示例

    本文实例讲述了php实现微信模拟登陆.获取用户列表及群发消息功能.分享给大家供大家参考,具体如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 ...

  9. Android之QQ授权登录获取用户信息

    有时候我们开发的app须要方便用户简单登录.能够让用户使用自己的qq.微信.微博登录到我们自己开发的app. 今天就在这里总结一下怎样在自己的app中集成QQ授权登录获取用户信息的功能. 首先我们打开 ...

随机推荐

  1. Java设计原则—迪米特法则(转)

    定义: 迪米特法则(Law of Demeter,LoD)也称为最少知识原则(Least Knowledge Principle,LKP). 一个对象应该对其他对象有最少的了解.通俗地讲,一个类应该对 ...

  2. 『NiFi 学习之路』简介

    『NiFi 学习之路』简介 『NiFi 学习之路』入门 -- 下载.安装与简单使用 『NiFi 学习之路』资源 -- 资料汇总 『NiFi 学习之路』把握 -- 架构及主要组件 『NiFi 学习之路』 ...

  3. Word 中将正文中的参考文件标号链接到参考文献具体条目

    一.概论 在论文撰写过程中,不可避免地引用到参考文献.通常,论文格式要求我们在引用的正文后,使用中括号将参考文献章节中对应的出处条目序号引起来,例如: 有时,我们要建立起这两者之间的链接关系. 二.设 ...

  4. Winter-2-STL-B Brackets 解题报告及测试数据

    Time Limit:2000MS     Memory Limit:65536KB Description Given a string consisting of brackets of two ...

  5. web安全学习方向~两图胜千言~~

  6. jstack用法

    第一步先找出Java进程ID,我部署在服务器上的Java应用名称为mrf-center: root@ubuntu:/# ps -ef | grep mrf-center | grep -v grep ...

  7. CentOS 6.3编译安装LAMP环境笔记

    转载地址:http://www.jb51.net/article/54969.htm 最近抽空在虚拟机上测试成功了LAMP各个最新版本的整合编译安装,算是把之前的博文整合精简,以下内容均在CENTOS ...

  8. 寻路算法A*, JPS(跳点搜索)的一些杂谈

    A*是一个比较经典的启发式寻路算法.是基于dijkstra算法,但是加入了启发函数,使路径搜索效率更高.实现起来很简单.不过要做到通用性高,比如支持各种不同类型的地图,甚至不仅仅是地图,而是个图结构如 ...

  9. 关于Linq的对List<实体>去掉重复ID的一个小例子!

    注意 下面的代码只要ID相同(即使其他的不相同)都会过滤掉,简单来讲就是过滤掉ID相同的实体,如果ID相同,其他属性取第一个的值 List<Abc> list = new List< ...

  10. 【bzoj4976】宝石镶嵌(思维dp)

    题目传送门:bzoj4976 不得不说这是道脑洞dp,思路真的清奇. 我们可以发现,虽然n很大,但是k只有100,这里面似乎隐藏了什么玄机. 我们可以发现,设总共有$ tot $个二进制位在这n个数中 ...