一个知乎日报pwa

前几天写了一篇文章关于如何实现一个简单版的pwa应用,端午撸了一个简易版知乎日报pwa。

关于如何写一个pwa,这里就不多介绍了,请移步这里。应用使用vue+vuex+axios,API这里,这里做了跨域处理,可以直接访问,但是返回的图片链接却无法访问(forbidden),暂时没有解决这个问题。

应用构建

使用vue作为前端框架,由于有些数据共享问题,所以使用了vuex来做状态管理。由于是移动端,这里使用rem来做适配,只需要在项目初始化的时候设定全局字体大小即可(当然这个字体是很大的,你需要在组件中重新定义相应的字体大小)。

    var deviceWidth = document.documentElement.clientWidth;

    document.documentElement.style.fontSize = deviceWidth / 7.5 + 'px';

    // 页面宽度发生变化时动态生成根字体尺寸
    window.onresize = function () {
        var deviceWidth = document.documentElement.clientWidth;
        if (deviceWidth > 750) deviceWidth = 750; // Iphone6Plus的屏幕尺寸
        document.documentElement.style.fontSize = deviceWidth / 7.5 + 'px';
    }

页面主要三部分,头部,内容区以及侧边栏。

  1. 侧边栏主要是实现一个点击头部按钮滑出的动画效果,并没有做手势效果。
slider.png
  1. 头部就是一些常见的操作,不多只有最左侧的有效,为了弹出侧边栏,或者返回新闻列表页
head.png

红色区块点击弹出侧边栏,黑色区块这是返回首页

head.png

当然如果进入详情页变成箭头返回按钮,由于没有使用路由所以只能点击这里返回。

  1. 内容区分为一个轮播图和内容列表。
content.png

没有请求到图片,将就点了。

坑与填坑

  1. 请求借口返回的信息有些链接是基于http的所以这里需要转成https直接正则替换即可
  2. 内容详情返回的是html字符串以及css链接,渲染html字符串直接使用指令v-html即可,但是由于样式库加载过慢导致页面乱,所以这里用一个粗暴的方法,先隐藏内容,等css请求回来之后再显示。css的地址需要跨域所以采用fetch请求,我们只需要请求返回结果即可,而不用返回具体值:
        fetch(cssUrl.replace(/http/g,'https'), {mode:'no-cors'})
            .then(res => {
                that.cssLoaded = true;
            })
  1. 在调用vuex的store时,使用对象解构赋值(es7),所以先安装babel-preset-stage-3,然后.babelrc文件要配置下
"presets": [
    ["latest", {
      "es2015": { "modules": false }

    }],
    "stage-3"
  ]

pwa查看

由于pwa基于https,所以这里使用ngrok做代理,便于我们查看,当然你可以把做好的应用直接放到github上来查看。
关于ngrok的使用直接看官网即可,基础使用一看就懂https://ngrok.com

实现效果

在手机上使用google浏览器打开,并添加到桌面

image.png

添加到手机桌面,左侧是原生App, 右侧是pwa


Screenshot_2017-05-31-14-46-56.jpg

配置的启动页


Screenshot_2017-05-31-14-47-12.jpg

打开之后
Screenshot_2017-05-31-15-55-13.jpg

我们可以看到,打开之后将浏览器的头部隐藏了,非常像一个原生APP。

断网之后

Screenshot_2017-05-31-14-48-04.jpg

由于没有缓存信息,所以页面为空,但头部依然有,而且可以打开侧边栏。我们知道网页都可以添加到桌面,但是断网之后, 就成了这样

Screenshot_2017-05-31-15-57-52.jpg

项目地址https://github.com/Stevenzwzhai/zhihu-daily
演示地址https://stevenzwzhai.github.io/zhihu-daily/

注:修复图片防盗链接,但是由于使用第三方缓存,所以可能会加载有点慢。

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,400评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,016评论 4 62
  • 收拾碗筷时打开冰箱门 发现里面还躺着半碗没煮的面 这不是手工擀面吗?! 是他亲手做的! 为我的生日,亲手做的面! ...
    白玉仙子阅读 408评论 0 0
  • 顾小轴阅读 409评论 0 0
  • 从前有一个花园,花儿们自由快乐的生长着,有些颜色艳丽,有些素雅,有些浓烈,每一朵都不一样,花园里还有各种各样的...
    yoga唯阅读 547评论 0 4