产品日常——动手写个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>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,524评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,869评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,813评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,210评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,085评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,117评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,533评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,219评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,487评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,582评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,362评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,218评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,589评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,899评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,176评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,503评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,707评论 2 335

推荐阅读更多精彩内容

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