0.序

玩阴阳师的肝帝们都知道,每天早上5点和下午6点会刷新两次封印任务,每次做任务时最蛋疼的就是找各种怪物对应的副本以及神秘线索。 阴阳师提供了 网易精灵 可以进行一些数据查询,但体验实在太感人,所以大多数人选择使用搜素引擎搜索怪物分布及神秘线索。

而每次使用搜索引擎查找又十分不方便,所以笔者决定写一个查询阴阳师妖怪分布的小程序,力求做到使用快捷体验更快捷,把更多的时间留给狗粮和御魂。

恰好上周末有两天时间,所以立马开写。

1.构思与设计 ( 3小时 )

1.1 构思

要做的小程序主要功能就是查询功能,所以主页应该像搜索引擎一样简洁,搜索框是肯定需要的;

主页包含热门搜索,缓存最热式神的搜索;

搜索支持完整匹配或者单字匹配;

点击搜索结果直接跳转到式神详情页;53. 式神详情页应该包含式神的图鉴、名称、稀有度、出没地点,并且出没地点按妖怪数量从多到少排序;

加入数据报错及提建议的功能;

支持用户个人的搜索历史;

小程序的名字,综合考虑小程序的功能最后决定叫做 式神猎手 ( 其实这是最后开发完成后才想好的 );

1.2 设计

构思好后笔者就开始用笔者半吊子的 PS 水平设计了下草图,大概是这个样子:

嗯,最主要的首页和详情页设计好就行,然后就可以开始具体考虑怎么做了!

1.3 技术架构

前端毫无疑问就是微信小程序咯;

后端使用 Django 提供 Restful API 服务;

当前最热搜索用 redis 做缓存服务器进行缓存;

个人搜索记录就使用微信小程序提供的 localstorage ;

式神分布信息使用爬虫爬取清洗,格式化为 json , 入库前再做人工检查;

式神图片及图标直接爬取官方资料;

自己制作爬不到的式神图片及图标;

小程序要求 HTTPS 连接,恰好笔者之前搞过,可以直接看这里 HTTPS 免费部署指南

到此,正式开发前的准备得当后,我们就可以开始正式开发了

2. API 服务开发 ( 5小时 )

Django 的 API 服务开发笔者之前经常做,所以有比较完整的解决方案,可以参考这里 django-simple-serializer

之所以花了 5 个小时是因为近 4 个小时在增加 django-simple-serializer 对 Django ManyToManyField 中 through 特性的支持。

简而言之, through 特性就是可以使多对多关系的中间表增添一些额外的字段或属性,例如: 怪物副本和怪物之间的多对多关系就需要增加一个储存每个副本有多少只相应怪物数量的字段 count。

搞定 through 支持后 API 的构建就很快啦,主要有五个 API :

搜索接口;

式神详情接口;

式神副本接口;

热门搜索接口;

反馈接口;

写好接口后添加一些 mock data 以供测试;

3. 前端开发 ( 8小时 )

前端花了最久的时间。

一方面笔者真的是个后端工程师,前端属于半路出家,另一方面小程序有一些坑。 当然,最主要的是一直在调整界面效果,这里花了大量时间。

写小程序的整体体验笔者感觉就和写 vue.js 一摸一样,只不过一些 html 标签没办法使用,而是需要按小程序官方提供的组件进行书写, 这里有一点感受就是,小程序本身组件化的设计思路应该是借鉴了 React 而语法之类的应该是借鉴了 vue.js 。

最后前端开发完毕后主要分为这几个页面:

主页 ( 搜索页 );

式神详情页;

我的页面 ( 主要是放搜索历史和免责申明等等东西 );

反馈界面;

声明界面 ( 为何需要这个界面? 因为所有图片及一些资源都是直接抓取阴阳师官方的资源,所以这里需要申明只是非盈利性质的使用,版权乱七八糟的都还是阴阳师的 )。

哎,丑媳妇早晚要见公婆,这里不得不放最后开发出来的界面图了

对于微信小程序的入门及基础,笔者就不在这里多讲了,相信到现在对微信小程序有关注的开发者或多或少自己写个简单的 demo 肯定是没问题的,我就主要讲一讲我在开发中遇到的坑:

3.1 background-image 属性

在写式神详情页的时候两个地方需要用到 background-image 属性设置背景图,在微信开发者工具中一切显示正常,但一到真机调试就没有办法显示,最后发现小程序的 background-image 在真机不支持引用本地资源,解决方案有两种:

使用网络图片: 考虑到背景图的大小,笔者放弃了这种方案;

使用 base64 编码图片。

正常来讲,css 中的 background-image 就支持 base64 ,这种方案相当于把图片直接用 base64 编码成一段 base64 码进行储存,在使用时这样使用即可:

background-image: url(data:image/image-format;base64,XXXX);

image-format 为图片本身的格式,而 xxxx 就是图片经过 base64 后得到的编码。这种方式其实是一种变相引用本地资源的方式,好处在于可以减少请求图片的次数,而缺点则是会增大 css 文件并使其不是那么好看。

最后笔者选择第二种方式主要还是考虑到图片的大小以及 wxss 的增大在可接受范围内。

3.2 template

小程序支持模版,但要注意模板拥有自己的作用域,只能使用data传入的数据。

另外,在传入数据时需要将相关数据解构传入,在模版内部是直接以 {{ xxxx }} 的形式进行访问,而不是像在循环中 {{ item.xxx }} 这种访问形式;

关于解构:

三个 . 就是解构操作;

一般 template 都会放在 单独的 template 文件中让其他文件进行调用,而不会直接写在正常的 wxml 中。 比如笔者目录大概是这样的:

├── app.js

├── app.json

├── app.wxss

├── pages

│   ├── feedback

│   ├── index

│   ├── my

│   ├── onmyoji

│   ├── statement

│   └── template

│   ├── template.js

│   ├── template.json

│   ├── template.wxml

│   └── template.wxss

├── static

└── utils

关于其他文件调用 template,直接使用 import 即可:

然后在需要引用模版的地方:

这里遇到另一个问题,template 对应的样式写在 template 对应的 wxss 中并没有作用,需要写在调用 template 的文件的 wxss 中,比如 index 需要使用 template 则需要将对应的 css 写在 my/my.wxss 中。

4. 爬取图片资源 ( 2小时 )

式神的图标及形象图基本上阴阳师官网都有,这里自己做也不现实,所以果断写爬虫爬下来然后存到自己的 cdn 。

大图和小图都在 http://yys.163.com/shishen/index.html 这里可以找到。 一开始考虑爬取网页然后 beautiful soup 提取数据,后面发现式神数据竟然是异步加载的,那就更简单了,分析网页得到 https://g37simulator.webapp.163.com/get_heroid_list 直接返回了式神信息的 json 信息,所以很容易写个爬虫就可以搞定了:

# coding: utf-8

import json

import requests

import urllib

from xpinyin import Pinyin

url = "https://g37simulator.webapp.163.com/get_heroid_list?callback=jQuery11130959811888616583_1487429691764&rarity=0&page=1&per_page=200&_=1487429691765"

result = requests.get(url).content.replace('jQuery11130959811888616583_1487429691764(', '').replace(')', '')

json_data = json.loads(result)

hellspawn_list = json_data['data']

p = Pinyin()

for k, v in hellspawn_list.iteritems():

file_name = p.get_pinyin(v.get('name'), '')

print 'id: {0} name: {1}'.format(k, v.get('name'))

big_url = "https://yys.res.netease.com/pc/zt/20161108171335/data/shishen_big/{0}.png".format(k)

urllib.urlretrieve(big_url, filename='big/{0}@big.png'.format(file_name))

avatar_url = "https://yys.res.netease.com/pc/gw/20160929201016/data/shishen/{0}.png".format(k)

urllib.urlretrieve(avatar_url, filename='icon/{0}@icon.png'.format(file_name))

然而,爬完数据后发现一个问题,网易官方的图片都是无码高清大图,对于笔者这种穷 ds 大图放在 cdn 上两天就得破产,所以需要批量将图片转成既不太大又能看的过去。嗯,这里就可以用到 ps 的批处理能力了。

打开 ps ,然后选择爬到的一张图片;

选择菜单栏上的“窗口”然后选择“动作;

在“动作”选项下,新建一个动作;

点击圆形录制按钮开始录制动作;

按正常处理图片等顺序将一张图片存为 web 格式;

点击方形停止按钮停止录制动作;

选择菜单栏上的 文件-自动-批处理-选择之前录制的动作-配置好输入文件夹和输出文件夹;

点击确定就可以啦;

等批处理结束,期间刷个御魂啥的应该就好了,然后将得到的所有图片上传到静态资源服务器,图片这里就处理完啦。

5. 式神数据爬取 ( 4小时 )

式神分布数据网上比较杂并且数据很多有偏差,所以斟酌再三决定采用半人工半自动的方式,爬到的数据输出为 json:

{

"scene_name": "探索第一章",

"team_list": [{

"name": "天邪鬼绿1",

"index": 1,

"monsters": [{

"name": "天邪鬼绿",

"count": 1

},{

"name": "提灯小僧",

"count": 2

}]

},{

"name": "天邪鬼绿2",

"index": 2,

"monsters": [{

"name": "天邪鬼绿",

"count": 1

},{

"name": "提灯小僧",

"count": 2

}]

},{

"name": "提灯小僧1",

"index": 3,

"monsters": [{

"name": "天邪鬼绿",

"count": 2

},{

"name": "提灯小僧",

"count": 1

}]

},{

"name": "提灯小僧2",

"index": 4,

"monsters": [{

"name": "灯笼鬼",

"count": 2

},{

"name": "提灯小僧",

"count": 1

}]

},{

"name": "首领",

"index": 5,

"monsters": [{

"name": "九命猫",

"count": 3

}]

}]

}

然后再人工检查一遍,当然还是会有遗漏,所以数据报错的功能就很重要啦。

这一部分实际写代码的时间可能只有半个多小时,剩下时间一直在检查数据;

一切检查结束后写个脚本直接将 json 导入到数据库中,检查无误后用 fabric 发布到线上服务器进行测试;

6. 测试 ( 2小时 )

最后一步基本上就是在手机上体验查错,修改一些效果,关闭调试模式准备提交审核;

此时已经是周日,哦,不对,应该是周一早上一点钟了:

不得不说,小程序团队审核速度很快啊,周一下午就审核通过了,然后果断上线。

最后放效果图:

感兴趣的同学欢迎扫码体验哟:

手机长按不能进入小程序,需要在 微信-发现-小程序-搜索-式神猎手 进入

7. 结尾

以上所有内容均已开源,欢迎大家参考:

python每天一个小程序_24小时从0到1开发阴阳师小程序相关推荐

  1. 小程序真机调试访问不了接口_24小时从0到1开发阴阳师小程序

    作者:rapospectre来源:https://www.rapospectre.com/blog/create-an-onmyoji-weapp-in-24-hours 玩阴阳师的肝帝们都知道,每天 ...

  2. 24小时从0到1开发阴阳师小程序 1

    原文地址:http://www.wxapp-union.com/portal.php?mod=view&aid=1499 0.序 玩阴阳师的肝帝们都知道,每天早上5点和下午6点会刷新两次封印任 ...

  3. Django+小程序:24小时从0到1开发阴阳师小程序

    点击上方"程序员大咖",选择"置顶公众号" 关键时刻,第一时间送达! 0.序 玩阴阳师的肝帝们都知道,每天早上5点和下午6点会刷新两次封印任务,每次做任务时最蛋 ...

  4. 从0到一开发微信小程序(6)—小程序常用API

    文章目录 其他相关文章 1.小程序API 1.1.路由 1.1.1.navigateTo(保留当前页面,跳转到应用内的某个页面,可以带参数) 1.1.2.redirectTo(关闭当前页面,跳转到应用 ...

  5. 从0到一开发微信小程序(2)——开发第一个小程序

    文章目录 其他相关文章 1.创建项目 2.小程序代码目录介绍 2.1.描述整体的app.* 2.2.描述各自页面的pages下面的目录 其他相关文章 从0到一开发微信小程序(1)--申请账号并安装开发 ...

  6. 从0到一开发微信小程序(5)—小程序WXML

    文章目录 其他相关文章 1.WXML 1.1.事件 1.1.1.系统 1.1.2.分类 1.1.2.1.冒泡事件(bindtap) 1.1.2.2.非冒泡事件(catchtap) 1.1.3.携带参数 ...

  7. 从0到一开发微信小程序(1)——申请账号并安装开发环境

    文章目录 其他相关文章 1.什么是微信小程序? 2.如何申请? 3.开发工具下载 其他相关文章 从0到一开发微信小程序(1)--申请账号并安装开发环境 从0到一开发微信小程序(2)--开发第一个小程序 ...

  8. 从0到一开发微信小程序(3)—小程序框架配置

    文章目录 其他相关文章 1.小程序框架 1.1.全局配置 1.1.1.Pages 1.1.1.1.entryPagePath 1.1.1.2.生成页面方式 1.1.2.window 1.1.3.tab ...

  9. 从0到一开发微信小程序(7)—小程序组件库(提高开发效率)

    文章目录 其他相关文章 1.组件库 1.1.TDesign 引入TDesign 使用 NPM 修改 app.json 使用组件 TDesign的应用 Rate 评分 Sticky 吸顶容器 Toast ...

最新文章

  1. ACM主要赛考察内容
  2. 最长上升子序列三种模板(n^2模板,二分模板,树状数组模板)
  3. 区县政府网站群建设新思路
  4. 基于一款 wk2168芯片的串口扩展
  5. Linux系统给进程绑核
  6. android ctrl 左键鼠标左键直接打开xml文件夹,设置Android Studio通过Ctrl+左键查看源码...
  7. Python内置函数之-struct
  8. 医疗信息化建设售后服务方案
  9. C# 使用openxml解析PPTX中的文本内容
  10. 李开复,活在AI与人群里
  11. Android 中网络连接检测和使用ping检测网络是否可访问
  12. web前端开发薪资,JavaScript的字面量与变量
  13. win10卸载程序灾难性故障_win10一直弹出卸载或更改应用程序的具体处理方法
  14. 使用Atmel ICE通过SWD接口调试Arduino MKR-WiFi-1010开发板
  15. ARM中断向量表与响应流程
  16. maven私服资源的上传与下载
  17. 两个实打实干活的同事离职了,老板连谈都没谈,一句挽留都没有,你怎么看
  18. 倘若生活没有改变,期盼又从何而来
  19. yso之Commons Collections
  20. MySQL 主从同步模式

热门文章

  1. 在线SVG转png的网站
  2. C# 重启IIS指定网站和指定应用程序池
  3. 倍福--上升沿和下降沿使用
  4. 假期,更想念我的宝宝和老婆了。
  5. Android——直播推流SDK
  6. 微信小程序原生接入腾讯云im(单聊,列表,聊天界面,自定义消息,自动回复)
  7. SOCKET编程 IO与NIO
  8. 性格测试分析软件,某种性格测试软件分析下的我——还是准呢。
  9. 2014年总结--不再年少
  10. mysql 结构体的charset_MYSQL源码分析之结构体浅析