两周撸一个掘金微信小程序

声明

这并非掘金官方小程序(貌似没有搜到掘金 APP 对应的官方小程序),彻底为第三方开发者开发,仅用于学习交流,禁止用于其余用途。若要使用官方正版,可访问掘金 官方网站,或下载掘金官方 APP,或访问掘金官方其余途径。html

该小程序全部 API 均来自掘金官方 web 网站和官方 AndroidAPP(以 web 为主),UI照抄参照的掘金官方 AndroidAPP(ver 5.4.3)。部分静态资源(icon、图片等)直接从掘金官方 apk 里拷出来的。git

该小程序代码已开源,点击可查看源码,可随意 star。也能够先扫描下方的小程序码直接体验。github

利益相关

web

很差意思,我改文章名字了

多是因为文章名字的缘故,在某个平台发的文章被判为垃圾信息了,而后,而后,我就更名字了。。。小程序

具体实现

前段时间写了一个简单的小程序 QuietWeather源码在这里,具体实现相关可查看这篇文章:两天撸一个天气应用微信小程序。可是这个 掘金小程序QuietWeather 彻底不是一个数量级的,说完具体实现,天都黑了,这里直接上效果图,感兴趣的能够 查看源码 。实际体验可扫描👆上面的小程序码。微信小程序

效果图

对应页面可打开掘金官方 APP 对比微信

PC 开发者工具录制,会有些卡顿markdown

文章数据入口调整了,也保留了动画,请酌情忽略 gif 卡顿工具

完成度

APP 里面的东西实在是很多,包括页面和交互,要彻底照抄实现确实须要一些时间和精力,UI 之类的都是简单测量+肉眼调试实现的,下面列出页面和交互的完成度,这里应该只是列出了绝大部分(仍是上面那句话,APP 里面的东西实在是很多),未列出、未实现的后续会根据时间、精力来实现。post

实际完成度请以代码为主(线上小程序也会持续更新)。

页面完成度

貌似不支持 markdown 待办事宜写法?QAQ

  • [x] 启动页
  • [x] 登陆、未登陆跳转逻辑和页面数据刷新逻辑等
  • [x] HOME、搜索、沸点、小册 TAB 涉及到的上拉、下拉刷新
  • [x] POST、ENTRY(文章类型不一样) 详情页
  • [ ] HOME TAB
    • [x] 首页
      • [x] 热门推荐
      • [x] 下部列表
    • [ ] 标签展现相关
  • [ ] 搜索 TAB
    • [x] 顶部轮播
    • [x] 热门文章
    • [ ] 搜索功能相关
    • [ ] 本周最热
    • [ ] 收藏集
      • [ ] ...
    • [ ] 活动
      • [ ] ...
  • [ ] 沸点 TAB
    • [ ] 推荐
      • [x] 顶部热门沸点
      • [x] 沸点列表
      • [x] 沸点详情
    • [ ] 话题
    • [ ] 动态
    • [ ] 发布沸点
  • [ ] 小册 TAB
    • [x] 小册列表
    • [ ] 小册详情
  • [ ] 个人 TAB
    • [ ] 我的主页
      • [x] 文章数据
      • [ ] 编辑
      • [ ] 关注、被关注列表
      • [x] 动态页
      • [x] 沸点页
      • [x] 原创文章页
      • [x] 收藏集
        • [ ] 收藏集详情页
      • [x] 喜欢的文章
      • [x] 关注的标签
        • [ ] 标签详情页
    • [x] 我喜欢的
    • [x] 收藏集
    • [ ] 已购小册
    • [x] 赞过的沸点
    • [x] 阅读过的文章
    • [x] 标签管理
      • [x] 已关注标签
      • [x] 全部标签
        • [x] 推荐标签
        • [x] 全部标签
    • [ ] 夜间模式
    • [x] 意见反馈(和官方 APP 有差别,这里是个简单的关于页)
    • [ ] 设置
      • [ ] ...
  • [x] 登陆页
  • [ ] 注册页
  • [ ] 修改密码页
  • [x] 其余完成部分...
  • [ ] 未完待续部分...

交互完成度

评论、留言、关注、添加到收藏集、喜欢、发表沸点等暂时均没有实现,由于 APP 里面的东西实在是很多......

  • [ ] 评论
  • [ ] 留言
  • [ ] 关注
  • [ ] 喜欢
  • [ ] 未完待续部分...

说明

  • 一、话说掘金的 API 域名(二级)真是多啊,小程序后台域名白名单最多只能配 20 个,如今已经占了 16 个了,感受要完整抄完实现掘金 APP 版小程序,配额不够啊。不行的话,就只能搭个 server 代理了;
  • 二、个别接口只有 APP 用到了,请求字段须要按照 web 的略做调整;个别接口也要设置对应的 header
  • 三、文章详情页返回的是整片文章的 html 格式的 content,这里使用的是开源的 wxParse 进行富文本解析;
  • 四、因为小程序的限制,第三方的 url 不能在 webview 中打开,因此文章里面的外链能点开算我输;
  • 五、开发时,个别细节须要稍微注意,好比:沸点 tab 页,若是已经滑到了顶部,onShow 获取新数据,不然,不刷新;未登陆时,首页 APP 调用的 API 是 get_recommended_entry就是懒为了方便小程序里仍然使用 get_entry_by_timeline;其余的不一一赘述,详情可 查看源码
  • 六、因为帐号权限等问题有些 API 须要天时地利人和,部分 API 返回的数据格式没有拿到,因此对应的页面也没有写,好比:系统消息页面(最近一直没有系统消息)等;
  • 七、部分数据可能未彻底覆盖,好比:用户消息这块,目前列举出的 categorycollectioncommentfollowcomment-likepin-likepin-comment,可能还会有其余消息类型,遇到了会一一补上;还有动态页,也是一样的问题;可能还有其余没有彻底覆盖的数据;
  • 八、点击某些文章进入详情页会提示 illegal token,亦或文章没有正常显示出来,应该是请求参数须要略做调整,或者文章类型须要判断。相似这样的小问题,后续会调整补充;
  • 九、小程序(非小游戏)在于一个 字,应该是一个应用的浓缩精华版,而不该该是一个内容丰富多彩的 APP100% 的复制版,这样会显得比较臃肿,此处应该有 but,该小程序仅仅是出于学习交流的目的,因此这个问题不在咱们的考虑范围内;
  • 十、登陆如今只能手机号登陆,邮箱登陆给忘记了,回头一并加上;
  • 十一、我也是有人生梦想的人;

转载请注明出处

相关文章
相关标签/搜索