当前位置:首页 > 科技  > 软件

云音乐2023年报前端大揭秘

来源: 责编: 时间:2024-07-09 07:02:58 714观看
导读前言每年的云音乐年度听歌报告,就像一个靠谱的老朋友,总会在忙碌一年的时光尽头里叩响记忆的大门。如果你曾错过了彼时的年报,不妨现在就拿起手机扫描上图的二维码,与往期的精彩视听来一场不期而遇的邂逅;如果你为年报中精

前言

每年的云音乐年度听歌报告,就像一个靠谱的老朋友,总会在忙碌一年的时光尽头里叩响记忆的大门。y4d28资讯网——每日最新资讯28at.com

  • 如果你曾错过了彼时的年报,不妨现在就拿起手机扫描上图的二维码,与往期的精彩视听来一场不期而遇的邂逅;
  • 如果你为年报中精巧而温馨的动画而深深着迷,请直接移步至本文的姊妹篇:「云音乐2023年报动效大揭秘」一探究竟;
  • 如果你恰好想了解年报中前端开发承担了什么样的角色、积累了哪些最佳实践 ——那么巧了,本文将从性能体验、质量管理、工程效率和一些笔者底层思考,帮助你逐步揭开年报的神秘面纱

性能体验

首次访问年报活动为例,好的用户体验主要包括以下几个方面:y4d28资讯网——每日最新资讯28at.com

  • 页面能秒级打开,页面到达率高、流失少;
  • 页面间转场展示流畅,不会出现卡顿;
  • 文本和图片内容在任何设备上都能完整展示,不出现缺失或者加载闪烁情况;
  • 音频或视频启播速度快,播放过程中不发生错乱或者卡顿情况;
  • 页面内的动效展示流畅,不会出现卡顿;

图片图片y4d28资讯网——每日最新资讯28at.com

简而言之,体验优涉及以下几个方面:y4d28资讯网——每日最新资讯28at.com

1、页面导航:包括首屏秒开,页面转场等y4d28资讯网——每日最新资讯28at.com

2、资源管理:包括图片、视频、音频和字体包等y4d28资讯网——每日最新资讯28at.com

3、页面适配:包括文本适配、动效适配和机型适配等y4d28资讯网——每日最新资讯28at.com

首屏秒开

首屏秒开是指用户从点击链接开始到展示页面内容大约在1s左右完成。整个过程经历如图所示:y4d28资讯网——每日最新资讯28at.com

容器初始化 -> CDN -> TCP 建连 -> html/js/css 加载解析 -> DOM / CSSOM 解析 -> 渲染布局 -> 绘制y4d28资讯网——每日最新资讯28at.com

图片图片y4d28资讯网——每日最新资讯28at.com

对于前端开发来说,优化难度是从右到左,越到左边就越需要跨团队合作来完成。可以简单的分析总结:y4d28资讯网——每日最新资讯28at.com

  • 在渲染/绘制阶段,可以隔离状态变化频繁的组件,减少无效状态引起的绘制。尽量选择由 GPU 渲染的 CSS3 来实现动效。逻辑实现的动效建议使用GSAP。
  • 在 DOM / CSSDOM 解析阶段,可以减少 DOM 的嵌套深度,减少使用 JavaScript 直接修改元素样式,减少不必要的 CSS,减少使用 CSS 选择器等。
  • 在 HTML / JS / CSS 加载解析阶段,可以通过构件工具对文件进行压缩。利用离线包能力,将这些资源提前下载到本地。
  • 在 CDN、TCP 建连阶段,更多依赖 App 网络库底层的优化,如使用 HTPP/2 减少 TCP 连接数。
  • 在容器初始化阶段,为了达到极致的打开速度,可以将 H5 容器进行预初始化。也可以建立容器复用池,减少容器创建的耗时。

页面管理

页面路由

为了有效管控年报中多个视图的高效展示和切换,采用了 SPA[1] 的形式对H5进行组织,同时为页面路由提供了路由表的配置。y4d28资讯网——每日最新资讯28at.com

路由表简单理解是各个子页面路由对象的集合,这个集合可以是全局数组对象,本地文件,或者服务端下发的配置。集合内的顺序决定了用户看到报告页顺序。这样也可以根据产品的述求,灵活调整集合内的顺序,这样就能动态调整页面顺序了。y4d28资讯网——每日最新资讯28at.com

各个子页面路由对象的属性具体如下。建议不用传统的 path,因为子页面数量多,且名称很难记忆,可以使用 routerIndex,这是子页面在交互稿中的位置代号,方便开发和调试。其中 ignoreSwipe 是使用在下节手势处理中「子容器接管父容器手势」的场景。y4d28资讯网——每日最新资讯28at.com

export interface PageProps {    model: unknown;    position?: number; // 页面埋点使用}export interface PageRouteProps {    c: ComponentType<PageProps>;    cId: string; // 当前页面唯一id    routerIndex: number | string; // 路由索引    ignoreSwipe?: boolean; // 是否忽略滑动,默认false}

手势处理

年报项目中用户可以通过点击、左右滑动、上下滑动来切换页面。为了防止手势冲突,全局只有一个父容器,各个报告页面是子容器;一些手势频控、页面状态变化等通用逻辑统一在父容器中实现。只在父容器中使用 hammerjs 做手势监听,子容器不再负责页面切换的手势监听,关键代码如下。y4d28资讯网——每日最新资讯28at.com

hammer = new Hammer(reportRef.current); hammer.get('swipe').set({ direction: Hammer.DIRECTION_ALL }); hammer.on('swipeleft', onNextPageWrap); hammer.on('swiperight', onPrePageWrap); hammer.on('swipeup', onNextPage); hammer.on('swipedown', onPrePage);

对于子容器,可能会有以下几种特殊情况:y4d28资讯网——每日最新资讯28at.com

情况一:如果子容器需要感知用户手势事件,可以监听父容器发出的自定义事件。y4d28资讯网——每日最新资讯28at.com

// 【翻页】动效:下一页export const ON_PAGE_NEXT = 'ON_PAGE_NEXT';// 【翻页】动效:上一页export const ON_PAGE_PREV = 'ON_PAGE_PREV';

情况二:如果子容器需要完全接管父容器的手势监听事件,例如年度歌手相关的所有页面。首先需要在路由表中将 ignoreSwipe=ture 设置忽略手势,然后在监听父容器发出的通知,进行自定义的事件处理。最后当子容器接管结束后,需要根据需要再次触发父容器的切换事件。关键代码如下:y4d28资讯网——每日最新资讯28at.com

const onNextPage = useCallback(    (nextAction) => {        if (currentPage >= len - 1) {            nextAction(); // 结束接管,再次触发父容器的切换事件            return;        }                setCurrentPage(currentPage + 1);    },    [currentPage, len]);useEffect(() => {        bus.on(ON_PAGE_NEXT, onNextPage);        return () => {            bus.off(ON_PAGE_NEXT, onNextPage);        };    }, [onNextPage, onPrePage]);

情况三:如果子容器存在特定区域需要响应特点手势,例如歌手来信页面左右切换是查看歌手来信。这时候需要子容器调用stopPropagation主动阻止手势向父容器传递。y4d28资讯网——每日最新资讯28at.com

转场实现

在路由表和手势处理准备就绪后,最后来看看页面之间转场的实现。年报页面的转场效果使用React官方实现的 react-transition-group 组件。由于篇幅限制,这里不详细介绍react-transition-group 组件的底层原理。结合路由表顺序和当前页面位置,通过 z-index 和 match 来控制子页面的层级和显示隐藏。使用 CSSTransition 实现页面间的进场和退场CSS动画。关键代码如下:y4d28资讯网——每日最新资讯28at.com

(pages || []).map((item, index) => {    // zIndex 和 match是关键代码    const zIndex = (pages.length - index) * 100;    const match = index === currentIdx;    return (        <div            key={item.cId}            style={{                zIndex,                pointerEvents: match ? 'auto' : 'none',                overflow: 'hidden',            }}>                <CSSTransition                    in={match}                    timeout={100}                    ...                    appear                    unmountOnExit>                    <item.c                        model={item.model}                        positinotallow={index} />                </CSSTransition>          </div>            );})

但是以上的页面转场存在一个问题,即页面之间只能存在一种转场方式。如何自定义页面之间的转场效果?基本思路是各自页面维护自己的转场效果;大部分页面只需将转场信息配置到路由表中;小部分页面可以通过页面上下文获得上一个或者下一个页面的信息,动态决定如何进场或者退场。基于该思路,改造路由表对象,新增一个 TransitionParams 协议,并且提供渐隐渐显的默认转场实现。关键代码如下:y4d28资讯网——每日最新资讯28at.com

export type TransitionParams = {    timeout: number | { appear?: number | undefined; enter?: number | undefined; exit?: number | undefined };    classNames: CSSTransitionClassNames;};export interface PageRouteProps {    c: ComponentType<PageProps>;    cId: string; // 当前页面唯一id    routerIndex: number; // 路由索引    transition: TransitionParams; //默认是渐隐渐显的转场效果    ignoreSwipe?: boolean; // 是否忽略滑动,默认false}

CSSTransition 配合改造后的关键代码如下:y4d28资讯网——每日最新资讯28at.com

<CSSTransition    in={match}    timeout={item.transition.timeout}    // 关键代码    classNames={item.transition.classNames}    appear    unmountOnExit>        <item.c model={item.model} positinotallow={index} /></CSSTransition>

资源管理

资源管理主要任务是将网络资源下载到本地,最终将本地资源加载到内存,以便程序可以使用这些资源。优化资源管理可以有效提高年报用户体验。通常开发者会通过压缩资源的大小,并通过内容分发网络(CDN)加快资源的下载速度。但是除了这些还有其他通用的方法呢?y4d28资讯网——每日最新资讯28at.com

在介绍具体优化手段前,先来看以下关键字,这些是性能优化的通用方法。y4d28资讯网——每日最新资讯28at.com

  • 提前 preload:提前准备必要的资源,提升加载速度
  • 同步 sync:串行执行当前任务,确保执行任务的优先级
  • 异步 async:工作线程异步执行,处理比较耗时的操作,不阻塞主线程
  • 懒加载 lazy:又称按需加载,不浪费请求
  • 缓存 cache:将资源缓存到内存或者磁盘本地,减少不必要的网络请求
  • 延迟 defer:不立即执行任务,延迟执行

总结如下图:y4d28资讯网——每日最新资讯28at.com

图片图片y4d28资讯网——每日最新资讯28at.com

接下来,将从图片、视频、字体包等各个资源,进一步解析如何结合上述关键词进行优化。y4d28资讯网——每日最新资讯28at.com

图片

关键字:提前 preload、懒加载 lazy、缓存 cache

图片资源占整个年报项目资源中的比例是最高的,大概 70% 左右。所以图片展示速度是否足够快和内容是否完整都会直接影响用户体验。y4d28资讯网——每日最新资讯28at.com

优先将图片资源使用 tinypng 进行手动压缩,在不失真的情况下,保证图片大小足够小。其次正确选择图片格式能有效减少图片大小。其中图片格式很多,主流的有:y4d28资讯网——每日最新资讯28at.com

  • SVG 是基于XML的矢量图片格式,不失真无限放大。支持动画。
  • JPEG 是有损压缩,不支持透明度或者动画。
  • PNG 是无损压缩,支持透明度。APNG 是 PNG 的扩展,支持动胡奥。
  • WebP 是无损和有损压缩,支持动画或者透明度。
  • GIF 是位图图片格式,支持动画。

不同图片格式在不同场景上使用。格式没选准确,会导致资源浪的费。如在「年度总览」一页中,海浪

本文链接:http://www.28at.com/showinfo-26-99645-0.html云音乐2023年报前端大揭秘

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 我们聊聊如何分析Rust进程使用了多少内存?

下一篇: 我让代码,学会了自动评审!提高80%的交付质量!

标签:
  • 热门焦点
  • JavaScript 混淆及反混淆代码工具

    JavaScript 混淆及反混淆代码工具

    介绍在我们开始学习反混淆之前,我们首先要了解一下代码混淆。如果不了解代码是如何混淆的,我们可能无法成功对代码进行反混淆,尤其是使用自定义混淆器对其进行混淆时。什么是混
  • 三言两语说透设计模式的艺术-简单工厂模式

    三言两语说透设计模式的艺术-简单工厂模式

    一、写在前面工厂模式是最常见的一种创建型设计模式,通常说的工厂模式指的是工厂方法模式,是使用频率最高的工厂模式。简单工厂模式又称为静态工厂方法模式,不属于GoF 23种设计
  • 三言两语说透设计模式的艺术-单例模式

    三言两语说透设计模式的艺术-单例模式

    写在前面单例模式是一种常用的软件设计模式,它所创建的对象只有一个实例,且该实例易于被外界访问。单例对象由于只有一个实例,所以它可以方便地被系统中的其他对象共享,从而减少
  • Java NIO内存映射文件:提高文件读写效率的优秀实践!

    Java NIO内存映射文件:提高文件读写效率的优秀实践!

    Java的NIO库提供了内存映射文件的支持,它可以将文件映射到内存中,从而可以更快地读取和写入文件数据。本文将对Java内存映射文件进行详细的介绍和演示。内存映射文件概述内存
  • Temu起诉SHEIN,跨境电商战事升级

    Temu起诉SHEIN,跨境电商战事升级

    来源 | 伯虎财经(bohuFN)作者 | 陈平安日前据外媒报道,拼多多旗下跨境电商平台Temu正对竞争对手SHEIN提起新诉讼,诉状称Shein&ldquo;利用市场支配力量强迫服装厂商与之签订独家
  • 阿里瓴羊One推出背后,零售企业迎数字化新解

    阿里瓴羊One推出背后,零售企业迎数字化新解

    作者:刘旷近年来随着数字经济的高速发展,各式各样的SaaS应用服务更是层出不穷,但本质上SaaS大多局限于单一业务流层面,对用户核心关切的增长问题等则没有提供更好的解法。在Saa
  • AI芯片初创公司Tenstorrent获三星和现代1亿美元投资

    AI芯片初创公司Tenstorrent获三星和现代1亿美元投资

    Tenstorrent是一家由芯片行业资深人士Jim Keller领导的加拿大初创公司,专注于开发人工智能芯片,该公司周三表示,已经从现代汽车集团和三星投资基金等
  • iQOO 11S新品发布会

    iQOO 11S新品发布会

    iQOO将在7月4日19:00举行新品发布会,推出杭州亚运会电竞赛事官方用机iQOO 11S。
  • DRAM存储器10月价格下跌,NAND闪存本月价格与上月持平

    DRAM存储器10月价格下跌,NAND闪存本月价格与上月持平

    10月30日,据韩国媒体消息,自今年年初以来一直在上涨的 DRAM 存储器的交易价格仅在本月就下跌了近 10%,此次是全年首次降价,而NAND 闪存本月价格与上月持平。市
Top