产品日常——动手写个App下载浮层

http://www.mindtheproduct.com/2011/10/what-exactly-is-a-product-manager/

我不生产代码,我只是代码的搬运工。

为了增强工具型App的运营能力,我们在上个版本加强了产品的内容功能。由运营的同学每天筛选、编辑一些高质量的用车文章或交通信息推送给用户。上线运营一段时间后发现,虽然文章List的整体位置处于首页中下屏,部分小屏机型(如iPhone4s、iPhone5)甚至需要滑屏才能看到,但PV还是很可观的。页面的分享率(分享次数/PV),在1%~2%左右。虽然不是很高,但是考虑到近期App的推广预算缩水,我想在分享的文章页上加一个推广浮层,顺便带一点下载。

由于这个想法不算正式需求,而且效果无法评估(其实是没啥底气,1%的分享率再去带下载效果不会很好,但聊胜于无啊),所以就准备自己来搞了。

实现逻辑很简单,对用户浏览的文章页面判断:

  1. 是否在App的Web View中
  2. 如果是,则不显示下载浮层
  3. 如果不是,则在顶部显示一个下载浮层
  4. 用户点击浮层,下载安装包

第一步,首先判断用户是在App中浏览文章,还是通过分享的链接打开的。方法就是对当前浏览器(广义)的UA([User Agent](User Agent))做标识符匹配。因为,为了便于后台的统计分析,开发者一般会修改默认的UA,添加一些自定义的标记(比如,比如UA+版本号、项目名称等)。我们通过正则表达式来匹配这些特殊标记,就可以判断出来是不是自己人。

Talk is cheap show me the code.

<p>
    <img id="landing"  

         src="http://sample.com/g2/M00/95/1A/wKjmqlcscRuAQboOAADafTTt8bg1116180" 

         style="position:fixed;width:100%;left:0;top:0;display:none;" 

         onclick="app_landing();"/>
</p>

<script>
function app_landing() {
    location.href = 'http://sample.com/apps/download?channel=sampletextlink';
}
</script>    

<script>
   if (navigator.userAgent.toLowerCase().match(/thisapp/) == null) {
     var banner = document.getElementById('landing');
     banner.onload = function() {
     document.getElementsByTagName('body')[0].style.marginTop = banner.height + 'px';
    };
     banner.style.display = 'inline';
    }
</script>

第一段HTML代码在文章页中插入了一张浮层图片,点击时触发event执行第二段的JS去下载安装包;第三段的JS来完成判断——是否是在App中打开文章页,并且控制浮层图片置顶显示。

最后,测试效果如下图。

iOS上显示效果:上图为App中浏览,下图为微信中浏览

本来到这里就应该结束了,我可以满怀期待地等待后台统计结果。谁知道打开Android测试机一看,App中的文章居然也带着下载浮层 !天了噜,为什么第2个JS中的判断代码在Android机上失效了?

一问Android的工程湿才知道,他当初并没有单独为这个Web View设置自定义UA!当我默默地把这条"bug"提交jira后,陷入了沉思···

由于没有HotFix,下次发版之前这个bug是解决不了了。那么现在,我只能增加一项判断来屏蔽掉所有的Android用户了。想到我们的Android用户要比iOS用户多几倍,我眼泪就流下来···

在网上搜了下如何通过UA来判断苹果系统,将上面的第二个JS修改如下:

<script>
   var u = navigator.userAgent;
   var isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/);
   if (navigator.userAgent.toLowerCase().match(/driverhelper/) == null && isiOS) {
      var banner = document.getElementById('aves-landing');
      banner.onload = function() {
      document.getElementsByTagName('body')[0].style.marginTop = banner.height + 'px';
      };
   banner.style.display = 'inline';
   }
</script>

好了,现在Android用户不会在App中看到奇怪的下载提示了(通过isiOS判断后,只有iOS的用户可以看到这条下载浮层)。但是,一下子减少了70%的用户,求心理阴影面积。

<small>注:以上代码的部分变量名和url做了替换,仅作参考示例。</small>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,865评论 25 709
  • 内容抽屉菜单ListViewWebViewSwitchButton按钮点赞按钮进度条TabLayout图标下拉刷新...
    皇小弟阅读 47,069评论 22 665
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 14,780评论 4 61
  • 最近追了一部三生三世的剧,感觉自己好像比较喜欢虐心的部分,而到了两人恩爱,互诉衷肠的部分呢,就觉得好假。 为什...
    luccy99阅读 3,385评论 0 0
  • 特斯拉,SpaceX,领英,Youtube,Yelp,Yammer这些耳熟能详的公司创始人都来自paypal这家公...
    平凡是一种势阅读 3,996评论 3 5

友情链接更多精彩内容