查看详情

使用 DOMParser 解析 XML 文件

大家可能偶尔会有碰到在 Web 端处理 XML 的文件 Case. 之前大家可能第一时间想的是正则表达式。 我们经常用它来进行标签或者属性的匹配。 但是今天会给大家带来一种全新的思路。我们知道 XHTML 是 XML 的子集。而且很早 HTML 就开始自己自定义的标签了。因此我们可以尝试借助 DOM Node 的思想把我们的 XML 文件字符串来进行 Dom 节点的转换。 var parser, xmlDoc; var text = `<?xml version="1.0" encoding="UTF-8"?> <!--Generated with https://github.com/google/shaka-packager version v1.5.1-c540e5a-release--> < 详情 »

查看详情

记一次胃镜体验

记一次胃镜体验 这么大终于体验了一次胃镜; 之前一直对胃镜保持一种神秘感,感觉东西从嘴巴进去然后一直向里面探视,感觉怪怪的。要是自己肯定会恶心干呕的。然而这次体验却出气怪。差别非常大。 背景 先说说背景: 自己是差不多一周前,一次空腹跑完步后,回家吃完饭,第二天开始隐隐约约有些上腹胀痛。持续了四五天。才开始不太重视,因为以前觉得胀痛,一会就好了。结合去年的类似情况,去医院,医生了开了几道慢性的胃炎的药,吃了之后也好了一些。所以自己也就没当回事。 但是这次似乎有些严重,因为每次吃完饭的感觉特别明显,感觉有东西堵在那里。于是周四还是去了医院看下具体什么原因。医生第一时间还是觉得是慢性胃炎,调理一下。但是这次又觉得,结合去年情况,建议自己做个胃镜,看看究竟什么情况。可能随着癌症的案例越来越多,恐怕很多人也是会非常担心是不是会有这么个情况,因为早期的胃癌是非常难以发现的。大多确疹都是中后期了。所以患者心理特别在意,其实也可以尝试做一个。 当然如果你有补充医疗保险,其实真的可以尝试一下,而且胃镜虽然也叫侵入式手术,但是远远没有那些常规手术比较。尤其无痛胃镜,非常快,很多人说30-45分钟就完成了。如果你年龄超过30岁了,医生也是建议有条件的可以每隔2-3年做一次胃镜检查。 这里还有一个指标,就是 C14 的幽门螺旋杆菌的感染测试,如果是阴性的话,可以暂时不用做,因为从概率学上分析,幽门没有感染, 详情 »

查看详情

loadedData,loadedMetadata,canplay 什么时候播放最好

最近一直在做 MSE 相关的事情,机缘巧合下碰到了关于 ReadyState 和它有可能触发的事情的研究,于是写下这篇文章作为记录。 前面一篇文章 HTML5 Video 元素 Ready State 分析 分析了 readyState 状态的具体含义,今天则会根据状态和关键事件来进行分析。 VIdeo 关于启动播放,有下面这些事件选择: loadedmetadata: 事件在元数据(metadata)被加载完成后触发 loadeddata: 事件在媒体当前播放位置的视频帧(通常是第一帧)加载完成后触发。 canplay: 事件在终端可以播放媒体文件时(但估计还没有加载足够的数据来播放媒体直到其结束,即后续可能需要停止以进一步缓冲内容)被触发。 canplaythrough: 事件在终端可以播放媒体文件时(估计已经加载了足够的数据来播放媒体直到其结束,而不必停止以进一步缓冲内容)被触发。 我们可以看到事件先后顺序是: loadedmetadata -> loadeddata -> canplay -> canplaythrough 我们再看看 3G 网速下的测试效果: 可以看到还是 loadedmetadata -& 详情 »

查看详情

[译]提升程序员生活质量的八个建议

原文链接:https://dev.to/wraith/my-8-tips-for-a-better-life-as-a-developer-1hfg 上周在邮件推送里面看到的一篇文章,真的让我觉得应该分享给大家。中国内卷的氛围,包括非常强的竞争压力,让我们忽视了作为程序员这份工作,应该如何快乐享受它,希望这篇文章能够帮助大家解决一些忧虑。毕竟我们工作,挣钱,晋升都只是一生中的少数亮点,一生中往往更多的是平淡,如何平淡中增加些乐趣,真的很重要。 我担任软件开发人员和工程师已经有 8 年多一点了,从我自己的经验以及从一些非常有才华的人那里学到了很多东西。在这篇文章中,我想分享一些真正让我的体验变得更好、更愉快的事情。有些是技术性的,有些只是一般生活技巧。但所有这些都改善了我在软件开发方面的生活和经验,希望通过分享这些课程和技巧,我可以帮助您避免一些我为了弄清楚它们而必须经历的不愉快的时光。 找到一个你喜欢工作的地方 译者注: 工作地点真的很重要,自己公司会有居家办公策略,有时候自己回去咖啡馆,感觉哪里效率并不会差,反而会更加专注,于是乎打开北京咖啡馆办公,也是自己计划一部分 您的环境对您的生活贡献很大。它可以增加或减轻压力,帮助您集中注意力或分散注意力,让您感到安全或不安全等等。因为它在我们每个人的生活中都扮演着不可或缺的角色,所以我认为从这里开始是合适的。 无论您是在办公室还是远程工作,您很可能可以采取一些措施来找到一个让您感觉“合适”的地方。我说“对”是因为这里每个人都会有所不同。有些人想要感到舒适和“宾至如归”。其他人想要一个不太舒适的区域, 详情 »

查看详情

【译】如何轻松的在你的Oculus 设备上测试的 WebXR 项目

原文链接: https://medium.com/@lazerwalker/how-to-easily-test-your-webvr-and-webxr-projects-locally-on-your-oculus-quest-eec26a03b7ee WebXR 目前还是特别小众的项目,所以在 Oculus 上调试也是需要一些实践的,希望这篇文章可以提升这方面的效率 最近,我花了很多时间使用 Babylon.js 制作 VR 游戏原型。我喜欢 Babylon 和 WebXR API 等技术如何让我利用现代 Web 开发的快速迭代时间构建 VR 体验,而不是使用 Unity 等较慢的编译循环。 也就是说,直到最近,我的开发工作流程中有一部分让我很恼火! 我的大部分测试都是在 Oculus Quest 上进行,开发则在 Mac 上进行。WebVR 和 WebXR API 都要求您从通过 HTTPS(而不是非安全 HTTP)提供服务的网页访问它们,大多数浏览器都为localhost. 由于我使用的是 Mac,因此无法通过 Quest 详情 »

查看详情

CSS 渐变字体实现

最近同事实现了 CSS 渐变的边框,于是乎自己想了下如何实现这个渐变字体。如果你有 SVG 经验的话,可能会非常快速的找到方法;当然如果你知道 canvas 肯定也是一个比较费力的解决方案,我们这里主要说下纯 CSS 的解决方案. 这里需要利用几个属性: background-clip 设置元素的背景(背景图片或颜色)是否延伸到边框、内边距盒子、内容盒子下面 -webkit-text-fill-color 指定了文本字符的填充颜色。若未设置此属性,则使用 color 属性的值。 我们通过填充渐变背景,并且将于背景延伸到字体内容即可。 span { font-size: 72px; font-family: arial; background: linear-gradient(90deg, #12c2e9, #c471ed, #f64f59); -webkit-background-clip: text; -webkit-text-fill-color: transparent; } 改变渐变方向 .flare { font-size: 72px; background: linear-gradient(#f12711, #f5af19); -webkit-background-clip: text; -webkit-text-fill-color: transparent; 详情 »

查看详情

TP 50 小计

在新公司由于工程师会更多的参加到数据分析中来,因此有的术语,尤其英文环境下还是需要去了解和学习的。比如 TP 50. 自己才开始看到时候还有些差异,但是透过上下文是能猜出什么意思来的。 这个是亚马逊的测试童鞋发给我的,自己之前确实没有太多统计学的工作经验,因此记录一下。 Top percentitle, TP 是一个统计学术语,表示一组数据按照从小到大排序,并计算器累计百分位则某一百分位的值就为这百分位数。 常见的我们会听到 TP50, TP90, TP99。 比如 一组数据 [10s, 1000s, 100s, 2s] 表示请求时长。 排完序后 [2s, 10s, 100s, 1000s] TP 50 就是 Math.ceil(4 * 0.5) = 2 也就是第二位的值 10s; TP 90 就是 Math.ceil(4 * 0.9) = 4 也就是最后一个 1000s。 有的运算会更加精细, 详情 »

查看详情

外企半年 Review

这大概是第三篇关于最近工作的一些回顾。前两篇可以在这里阅读: 来 Tubi 工作的前前后后 外企试用期回忆录 上一篇是3月份写的,那个时候刚过完试用期,至今差不多小半年左右,自己也算是扎稳了脚跟。自己觉得在外企和相对国内大厂,在呆过这么长之后,可以再做一次对比(自己在阿里巴巴-大文娱2017和现任公司的对比,仅仅来自个人的体验): 大厂 外企 工作时间 10-11 个小时(包含午餐) 8-9 个小时(包含午餐) 假期 5天年假 + 2 天路途假 15天年假 + 12 holiday 工作压力 比较累,感觉工作内容比较多 这个完全看自己,外企自由度很高,如果你想进一步,压力挺大,如果现状不错,压力相对轻松 工作难度 难度相对较小,可以找到的资源比较多 难度较大,找到的资源相对较小 福利 节假日礼物都有 节假日礼物都有 个人的工作认知变化 我觉得这九个月,一晃眼而过。我觉得这里面有一些和我之前工作认知上的差异: 美国的工程师很厉害。硬编码能力真的很强,比我们更加注意代码风格,而且文档和逻辑能力都很强, 详情 »

查看详情

HTML5 Video VideoPlaybackQuality 实现丢帧统计

在 Web 开发中,我们依赖于 Video 元素进行视频播放,相对 Android 或者 Windows 客户端程序,我们更加依赖浏览器测对 Video 元素提供了什么样的能力。 而如果我们需要对丢帧率进行统计,现在有了 VideoPlaybackQuality 来完成改功能。 目前主流浏览器都得到了支持 VideoPlaybackQuality 对象表示了一系列描述视频播放质量的指标。 可以通过 HTMLVideoElement.getVideoPlaybackQuality() 创建一个实例来获取。 里面包含下面的属性; .creationTime 一个用毫秒表示从开始页面浏览到对象创建的 DOMHighResTimeStamp 对象 .totalVideoFrames 表示相 HTMLVideoElement 自从创建起的已创建和丢弃帧数数量总和的值 .droppedVideoFrames 表示相关联的 HTMLVideoElement 自从创建起的已丢弃帧数数量值 .corruptedVideoFrames 一个表示相关联的 HTMLVideoElement 自从创建起的损坏帧数数量的值。一个损坏帧可能属于创建帧或丢弃帧 这样我们通过简单的 droppedVideoFrames / totalVideoFrames 来实现一个丢帧比例的计算,从而实现一个质量的保证。而 hls.js-fps-controller.ts 也是采用相关 API 来实现播控质量的控制。 checkFPSInterval( 详情 »

查看详情

HTML5 Video 元素 Ready State 分析

最近一直在做 MSE 相关的事情,机缘巧合下碰到了关于 ReadyState 和它有可能触发的事情的研究,于是写下这篇文章作为记录。 Video 元素维持内部几个非常重要的状态,这些都是只读的: paused 属性,你可以直接从 video elment 上读取,当你暂停视频的时候,Video 元素会讲这个属性值改为 true, 这里还有一些别的情况,我会在后面一篇文章分析 readyState 属性,当然你也可以从 Video 元素上读取,不同 readyState 意味着 video 的不同状态。 官方罗列了这些状态值: // video element ready state Enum const unsigned short HAVE_NOTHING = 0; const unsigned short HAVE_METADATA = 1; const unsigned short HAVE_CURRENT_DATA 详情 »