微信运动排行榜中某些好友的步数为何是昨天的@数据时间属性

微信运动排行榜中某些好友的步数为何是昨天的@数据时间属性,第1张

微信运动作为微信平台的小程序,实现原理很简单,从一个采集步数的设备获取数据然后在你好友圈(开启微信运行的好友)里进行当天排名呈现,默认是从本机获取数据(可配置)。

微信运动具有它的社交属性,利用用户的攀比心理,越来越多的人注重运动步数。使用过程中发现有时候会看到有些好友的步数是昨天的,这是为何呢?让我想到了步数的时间属性,怎么判断是当天的步数?当天数据又是怎么划分的呢?欢迎大家来到 测试有话说 第一季第二集,让我们聊聊数据的时间属性。

以91号早上7点的步数排行为例,第一名在中国(东8区),第二名在英国(零时区),比如中国是91号上午7点,则英国是831号晚上23点。

第一名的步数是91号的。

第二名的步数是831号的(步数和排行榜中的不一致的原因不清楚)。

是不是很奇怪,为何会造成这个现象呢?(可能平常大家只关注步数,却很少关注其他用户步数是哪一天的)。我就想到怎么判断是当天的步数?当天数据又是怎么划分的呢?运动步数的消息结构来解答这些问题。

微信运动步数来源于哪里呢?看下微信小程序中你的设置。

默认设置来自本机,当然可以设置为其他数据来源,只要开启蓝牙功能即可。

微信运动的数据结构长什么样子呢?从网上查了下,步数的两个参数为"timestamp": 1567292400 和 "step": 100,前者是是时间戳以秒为单位,后者是该时间点的步数。

从时间戳中我们可以得到什么信息呢?先看下时间戳的定义。

时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起到现在的总秒数。

时间戳为1567292400,如果在中国(东8区)则为2019-09-01 07:00:00。但如果在英国(零时区)则时间为2019-08-31 23:00:00,那么时间戳是多少呢?下面的命令告诉你答案

在零时区东Linux服务器上执行

$ date -d '2019-08-31 23:00:00' +"%s"

1567263600

在东8区的Linux服务器上执行

$ date -d @1567292400

2019年 09月 01日 星期天 07:00:00 CST

相信在介绍完时间戳的概念后,相信你已经知道了时间戳中只能获取到时间但包含时区信息,上边的例子可知,一个时间戳在不同时区的时间是不一样的。如果从不同时区采集的步数却在相同服务器(也就是时区一样)上处理然后进行排行,比如中国北京时间晚上23点进行排名冠军赛,此时英国下午15点,也就是说中国步数是某种意义上当天的,英国步数实际上从昨天16点到今天下午15点这段时间内的数据。

举例:微信运动在中国的时间戳为91号0点到91晚上23点,如果时间戳都一样的话,那么其他时区的步数可能就不是91号当天的步数。

如果是要优化的话,建议在处理带有时间属性的数据时,要带有时区的信息,一个时间戳搞不定的。

1) 新闻联播大家都在看吧,播报员在报到国际信息时会这么说:北京时间xxx,英国当地时间yyy,在英国发生什么大事。那么英国的新闻播报员怎么播报这个新闻呢?那就是British local time yyy, Beijing time xxx, what happened at China

中国播报员和英国播报员都做了时间戳+时区的转换,这样听众才知道事件的发生时间点。

2) 告警模块 中,告警管理者在东8区,告警代理分别在东3区和东5区,浏览器客户端有可能在东8区/3区/5区登录,也有可能在其他区登录。

如果东3区和东5区的告警代理将告警上报给东8区的告警管理,如果仅仅一个时间戳(在零时区看时间是一样的),对于东8区的告警管理来说转换后的时间是不一样的,如果能带上时区,转换后的时间是一样的。这里有个意思的问题,告警界面上呈现的时间应该是什么样的?想想新闻播报员:北京时间xxx,在英国发生某件大事。那么告警界面的告警发生时间应该呈现浏览器所在Windows主机相应时区的时间,换一个时区的浏览器查看,告警发生时间肯定不一样。

3) 安全模块中,比如要记录用户登录的时间点,那么所呈现的原理和告警是一样的。

4) 性能模块中,比如每个时区的用户,创建的性能任务的开始时间和结束时间,来自于创建任务时所登录的windows主机,任务创建的开始时间和结束时间到服务端后,服务端看到的时间也是和告警界面转换后是同样的道理。

1、传递参数为对象格式

若参数为对象则需先使用 JSONstringify()进行转换 , 接收后使用JSONparse()转为对象

但这样传参有一个问题,当对象数据长度过大时会报错,因为url传参时程序把过长的那段数据给截取掉了,导致数据转换回来时格式不对而报错。

2、传递参数中含有 = &等特殊字符

若传递参数中含有=,,&等特殊字符,无法正常传递参数,则需要进行编码解码。

解决:

这时可以再添加另一个API:encodeURIComponent(obj) 和 decodeURIComponent(optionsobj),在encodeURIComponent之前要用JSONstringify()先转换数据,decodeURIComponent之后再用JSONparse()转换回来。

encodeURIComponent(JSONstringify(obj)) 为跳转url时的转换方法。

JSONparse(decodeURIComponent(optionsobj)) 为接收参数页面的转换方法。

例如:

基于微信小程序轻快的特点,我们拟定了小程序界面设计指南和建议。设计指南建立在充分尊重用户知情权与 *** 作权的基础之上。旨在微信生态体系内,建立友好、高效、一致的用户体验,同时最大程度适应和支持不同需求,实现用户与小程序服务方的共赢。

为了避免用户在微信中使用小程序服务时,注意力被周围复杂环境干扰,小程序在设计时应该注意减少无关的设计元素对用户目标的干扰,礼貌地向用户展示程序提供的服务,友好地引导用户进行 *** 作。

每个页面都应有明确的重点,以便于用户每进入一个新页面的时候都能快速地理解页面内容。在确定了重点的前提下,应尽量避免页面上出现其它与用户的决策和 *** 作无关的干扰因素。

此页面的主题是查询,却添加了诸多与查询不相关的业务入口,与用户的目标无关,易造成用户的迷失。

去掉任何与用户目标不相关的内容,明确页面主题,在技术和页面控件允许的前提下提供有助于用户决策和 *** 作的帮助内容,比如最近搜索词等。

*** 作没有主次,让用户无从选择。

首先要避免并列过多 *** 作让用户选择,在不得不并列多个 *** 作时,需区分 *** 作主次,减轻用户的选择难度。

为了让用户顺畅地使用页面,在用户进行某一个 *** 作流程时,应避免出现用户目标流程之外的内容而打断用户。

用户本打算进行搜索,在进入页面时却被突如其来的模态抽奖框所打断;对于抽奖没有兴趣的用户是非常不友好的干扰;而即便有部分用户确实被“诱人”的抽奖活动所吸引,离开主流程去抽奖之后可能就遗忘了原本的目标,进而失去了对产品真正价值的利用和认识。

一旦用户进入我们的小程序页面,我们就有责任和义务清晰明确地告知用户身在何处、又可以往何处去,确保用户在页面中游刃有余地穿梭而不迷路,这样才能为用户提供安全且愉悦的使用体验。

导航明确,来去自如

导航是确保用户在网页中浏览跳转时不迷路的最关键因素。导航需要告诉用户,当前在哪,可以去哪,如何回去等问题。首先在微信系统内的所有小程序的全部页面,均会自带有微信提供的导航栏,统一解决当前在哪,如何回去的问题。在微信层级导航保持体验一致,有助于用户在微信内形成统一的体验和交互认知,无需在各小程序和其他微信页面的切换中新增学习成本或改变使用习惯。

微信导航栏

微信导航栏,直接继承于客户端,除导航栏颜色之外,开发者无需亦不可对其中的内容进行自定义。但开发者需要规定小程序各个页面的跳转关系,让导航系统能够以合理的方式工作。

微信导航栏分为导航区域、标题区域以及 *** 作区域。其中导航区控制程序页面进程。目前导航栏分深浅两种基本配色。

导航区(iOS)

微信进入小程序的第一个页面,导航区通常只有一个 *** 作——“返回”,即返回进入小程序前的微信页面。进入小程序后的次级页面,导航区的 *** 作为——“返回”和“关闭”。“返回”,即返回上一级小程序界面或微信界面。“关闭”,即在当前界面直接退出小程序,回到进入小程序前的微信页面。

导航区(Android)

导航区仅存在唯一 *** 作——直接退出小程序,回到进入小程序前的微信或系统桌面,安卓手机自带的硬件返回键执行返回上一级页面的 *** 作。

安卓导航存在一类特殊情况:当用户通过 *** 作区的菜单将小程序添加至安卓桌面,并从安卓桌面打开小程序时,小程序的首页,不展示导航按钮。仅展示小程序标题和 *** 作区。小程序次级页面,导航区只有返回上一级页面的 *** 作,而点击安卓手机自带的硬件返回键也起到相同作用。

微信导航栏自定义颜色规则(iOS和Android)

小程序导航栏支持基本的背景颜色自定义功能,选择的颜色需要在满足可用性前提下,和谐搭配微信提供的两套主导航栏图标。建议参考以下选色效果:

选色方案示例

页面内导航

开发者可根据自身功能设计需要在页面内添加自有导航。并保持不同页面间导航一致。但是受限于手机屏幕尺寸的限制,小程序页面的导航应尽量简单,若仅为一般线性浏览的页面建议仅使用微信导航栏即可。

开发者可选择小程序页面添加标签分页(Tab)导航。标签分页栏可固定在页面顶部或者底部,便于用户在不同的分页间做切换。标签数量不得少于2个,最多不得超过5个,为确保点击区域,建议标签数量不超过4项。一个页面也不应出现一组以上的标签分页栏。

其中小程序首页可选择微信提供的原生底部标签分页样式,该样式仅供小程序首页使用。开发时可自定义图标样式、标签文案以及文案颜色等,具体设置项如图标尺寸等参考可参考开发文档和WeUI基础控件库。

顶部标签分页栏颜色可自定义。在自定义颜色选择中,务必注意保持分页栏标签的可用性、可视性和可 *** 作性。

减少等待,反馈及时

页面的过长时间的等待会引起用户的不良情绪,使用微信小程序项目提供的技术已能很大程度缩短等待时间。即便如此,当不可避免的出现了加载和等待的时候,需要予以及时的反馈以舒缓用户等待的不良情绪。

启动页加载

小程序启动页是小程序在微信内一定程度上展现品牌特征的页面之一。本页面将突出展示小程序品牌特征和加载状态。启动页除品牌标志(Logo)展示外,页面上的其他所有元素如加载进度指示,均由微信统一提供且不能更改,无需开发者开发。

页面下拉刷新加载

在微信小程序内,微信提供标准的页面下拉刷新加载能力和样式,开发者无需自行开发。

微信下拉刷新错误使用案例

请避免以下错误使用情况,确保信息的可见性和页面的可用性。

页面内加载反馈

开发者可在小程序里自定义页面内容的加载样式。建议不管是使用在局部还是全局加载,自定义加载样式都应该尽可能简洁,并使用简单动画告知用户加载过程。开发者也可以使用微信提供的,统一的页面加载样式,如图中例所示。

模态的加载样式将覆盖整个页面的,由于无法明确告知具体加载的位置或内容将可能引起用户的焦虑感,因此应谨慎使用。除了在某些全局性 *** 作下不要使用模态的加载。

局部加载反馈

局部加载反馈即只在触发加载的页面局部进行反馈,这样的反馈机制更加有针对性,页面跳动小,是微信推荐的反馈方式。例如:

加载反馈注意事项

若载入时间较长,应提供取消 *** 作,并使用进度条显示载入的进度。

载入过程中,应保持动画效果;无动画效果的加载很容易让人产生该界面已经卡死的错觉。

不要在同一个页面同时使用超过1个加载动画。

除了在用户等待的过程中需予以及时反馈外,对 *** 作的结果也需要予以明确反馈。根据实际情况,可选择不同的结果反馈样式。对于页面局部的 *** 作,可在 *** 作区域予以直接反馈,对于页面级 *** 作结果,可使用d出式提示(Toast)、模态对话框或结果页面展示。

页面局部 *** 作结果反馈

对于页面局部的 *** 作,可在 *** 作区域予以直接反馈,例如点击多选控件前后。对于常用控件,微信设计中心将提供控件库,其中的控件都已提供完整 *** 作反馈。

页面全局 *** 作结果——d出式提示(Toast)

d出式提示(Toast)适用于轻量级的成功提示,15秒后自动消失,并不打断流程,对用户影响较小,适用于不需要强调的 *** 作提醒,例如成功提示。特别注意该形式不适用于错误提示,因为错误提示需明确告知用户,因而不适合使用一闪而过的d出式提示。

页面全局 *** 作结果——模态对话框

对于需要用户明确知晓的 *** 作结果状态可通过模态对话框来提示,并可附带下一步 *** 作指引。

页面全局 *** 作结果—结果页

对于 *** 作结果已经是当前流程的终结的情况,可使用 *** 作结果页来反馈。这种方式最为强烈和明确的告知用户 *** 作已经完成,并可根据实际情况给出下一步 *** 作的指引。

异常可控,有路可退

在设计任何的任务和流程时,异常状态和流程往往容易被忽略,而这些异常场景往往是用户最为沮丧和需要帮助的时候,因此需要格外注意异常状态的设计,在出现异常时予以用户必要的状态提示,并告知解决方案,使其有路可退。

要杜绝异常状态下,用户莫名其妙又无处可去,停滞在某一个页面的情况。上文中所提到的模态对话框和结果页面都可作为异常状态的提醒方式。除此之外,在表单页面中尤其是表单项较多的页面中,还应明确指出出错项目,以便用户修改。

异常状态——表单出错

表单报错,在表单顶部告知错误原因,并标识出错误字段提示用户修改。

从PC时代的物理键盘鼠标到移动端时代手指,虽然输入设备极大精简,但是手指 *** 作的准确性却大大不如键盘鼠标精确。为了适应这个变化,需要开发者在设计过程中充分利用手机特性,让用户便捷优雅的 *** 控界面。

由于手机键盘区域小且密集,输入困难的同时还易引起输入错误,因此在设计小程序页面时因尽量减少用户输入,利用现有接口或其他一些易于 *** 作的选择控件来改善用户输入的体验。

例中,在添加yhk时,采用摄像头识别接口来帮助用户输入。除此之外微信团队还对外开放例如地理位置接口等多种微信小程序接口,充分利用这些接口将大大提高用户输入的效率和准确性,进而优化体验。

除了利用接口外,在不得不让用户进行手动输入时,应尽量让用户做选择而不是键盘输入。一方面,回忆易于记忆,让用户在有限的选项中做选择通常来说是容易于完全靠记忆输入;另一方面,仍然是考虑到手机键盘密集的单键输入极易造成输入错误。例如图中,在用户搜索时提供搜索历史快捷选项将帮助用户快速进行搜索,而减少或避免不必要是键盘输入。

避免误 *** 作

因为在手机上我们通过手指触摸屏幕来 *** 控界面,手指的点击精确度远不如鼠标,因此在设计页面上需点击的控件时,需要充分考虑到其热区面积,避免由于可点击区域过小或过于密集而造成误 *** 作。当简单的将原本在电脑屏幕上使用的界面不做任何适配直接移植到手机上时,往往就容易出现这样的问题。由于手机屏幕分辨率各不相同,因此最适宜点击像素尺寸也不完全一致,但换算成物理尺寸后大致是在7mm-9mm之间。在微信提供的标准组件库中,各种控件元素均已考虑到了页面点击效果以及不同屏幕的适配,因此再次推荐使用或模仿标准控件尺寸进行设计。

利用接口提升性能

微信设计中心已推出了一套网页标准控件库,包括sketch设计控件库和Photoshop设计控件库,后续还将完善小程序组件,这些控件都已充分考虑了移动端页面的特点,能够保证其在移动端页面上的可用性和 *** 作性能;同时微信开发团队也在不断完善和扩充微信小程序接口,并提供微信公共库,利用这些资源不但能够为用户提供更加快捷的服务,而且对页面性能的提高有极大作用,无形之中提升了用户体验。

除了以上所提到的种种原则,建议接入微信的小程序还应该时刻注意不同页面间的统一性和延续性,在不同的页面尽量使用一致的控件和交互方式。

统一的页面体验和有延续性的界面元素都将帮助用最少的学习成本达成使用目标,减轻页面跳动所造成的不适感。正因如此,小程序可根据需要使用微信提供的标准控件,以达到统一稳定的目的。

微信内字体的使用与所运行的系统字体保持一致,常用字号为20,18,17,16,1413,11(pt),使用场景具体如下:

主内容Black黑色,次要内容Grey灰色;时间戳与表单缺省值Light灰色;大段的说明内容而且属于主要内容用Semi黑。

蓝色为链接用色,绿色为完成字样色,红色为出错用色Press与Disable状态分别降低透明度为20%与10%。

一、第一步,打开微信小程序开发工具,新建界面对应的JS文件,注意Page对象。

二、第二步,如果想要获取正在调试的手机或工具的品牌,可以使用brand。

三、第三步,微信小程序开发过程中,可以设置字体大小,使用fontSizeSetting查看。

四、第四步,查看使用的工具中使用的是哪种语言,可以使用language。

五、第五步,除了可以查看手机品牌,还可以查看手机型号,使用mode属性。

六、第六步,如果要查看设备像素比,可以使用pixelRatio属性。

扩展资料:

微信小程序如何找到?

一、打开手机微信,向下滑动屏幕就能看到你最近常用的小程序。

二、另外在发现页,最下面有“小程序”,可以找到使用过的小程序。

三、你也可以通过搜索和“附近的小程序”查找。

参考资料:

百度百科-微信

以上就是关于微信运动排行榜中某些好友的步数为何是昨天的@数据时间属性全部的内容,包括:微信运动排行榜中某些好友的步数为何是昨天的@数据时间属性、微信小程序页面跳转url传参,对象、数据过长、特殊字符问题、微信小程序怎么设计等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9486668.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-28
下一篇 2023-04-28

发表评论

登录后才能评论

评论列表(0条)

保存