新视点 这周请了 5 天的年假,回去了一趟老家,虽然很多事物没有什么变化,但认知世界的眼睛发生了变化,便看到了一些不曾留意过的东西。 そら 用树叶吹出来的声音,和吾辈想象中的差别有一点点大 ಡ ͜ ʖ ಡ 声音: https://1drv.ms/u/s!AqTwKbfzs-vyiocZXo9hbDbp7h7P2g 魔幻现实,退林返耕(小时候玩的空地前几年被挖了个大坑(卖地),现在居然种上农作物
立个 Flag,今年入坑 Kigurumi 并出一次漫展 简介 Kigurumi 是什么?能吃么? 是一种 cosplay 服装扮演,不能吃谢谢。 借用 Wiki 中的描述:“人偶扮演(着ぐるみ Kigurumi ?),是一种透过穿着类似 吉祥物服装的全身套装以在现实世界中达成还原卡通或动漫人物的 cosplay 形式。和 cosplay 不一样的是,表演者的脸会被 面具完整的包住,所穿着的服装也会掩盖住全身,借此表演者得以完全隐藏自己原本的身份,完全
汉诺塔问题 前言最近两个月一直在看 SICP 的 Youtube 课程,作为一个半路出家的人,自觉基础欠缺,至今已是工作的第四个年头,正如年初计划所言,仅仅依赖于热情去折腾各种简单的玩具已经不再能有效地提升自己了,需要系统化的学习和组织知识。虽然之前也买过实体书,但由于看起来比较难而且也没有风趣的讲解(看的有点枯燥,看完视频后感觉里面的教授真的太有趣了!),所以一直没能看下去(另外一本《算法》也是同样的命运)
2022 新春团建 这是自从来到帝都入职新公司之后,第一次出来一起团建,总体上感觉还是很有趣的。 首先,上午一起先去种了树,毕竟临近植树节了嘛 但实际上在我们走了之后就被拔了,种了拔拔了种,我们(公司和景点)都赢了,只有树苗默默被消耗着。。。 由于是下午到的酒店,所以爬不了长城,只能随便逛逛,这个时候人非常少,冷冷清清的,据说秋天人会很多。 然后就看到有个塔,所以就一起和同事爬了上去(看到很高的东西想上去不是很
Git 设置和取消代理 设置代理12git config --global http.proxy 'http://127.0.0.1:10800'git config --global https.proxy 'http://127.0.0.1:10800' 注:此处设置的代理 ip 和端口号都是本地存在的(SS/SSR 默认就是)。 取消代理12git config --global --unset http.p
工具网站 前端 2019 前端开发者学习路线汇总 工具 i18ns: 国际化 i18n 全语言翻译 codepen: 前端页面代码分享(HTML/CSS/JavaScript) appsgeyser: 封装前端/网站为 App cloudflare: CDN/免费的 HTTPS netlify: 前端免费 CI(持续集成) smms: 免费稳定的图床(国内) office-converter: 文档在线转
实现一个玩具 lisp 运行时与解析器 前言之前看元循环求值器一节中使用 lisp 实现了一个 lisp 的运行时,吾辈也尝试使用 ts 来实现它。首先,这里展示一张曾经在书中出现过的图,表示一个运行时的基本组成是由 eval 和 apply 组成(看起来很像太极就是了)。eval 负责执行一个表达式,在 lisp 中,所有的代码都是表达式,这没什么问题。apply 则负责执行一个函数,将计算实参列表,并创建一个新的闭包环境绑定到形参上
流与延迟计算 前言在此之前,吾辈介绍了如何 从函数中无中生有的构造数据结构。现在,吾辈将使用它构造一个更强大的数据结构:Stream(流)。 或许你曾经见过这张图 一些数据经过一系列的处理,然后得到结果,而只需要迭代每个元素一次,就像魔法一样。 之前的想法最初,吾辈的想法是让操作保存起来,只有等待某个显式调用的时候才真正执行。 即调用 map/filter/reduce 时将 action 与参数保存起来,等
cons: 无中生有的数据结构 前言lisp 中有一种有趣的数据结构,Cons,它使用函数闭包封装了一个两元组的数据结构,并在此之上构建出其他需要的任何数据结构。在此之前,虽然也知道闭包之类的概念,写过一些高阶函数,但并未想过可以使用函数来构建数据结构,下面吾辈会说明如何在 ts 完成。 lisp cons 的 wiki 基本定义如下 $$c=cons(a,b)\car(c)=a\cdr(c)=b$$ 初始实现cons 初始
vite 构建正确内联 svg 资源 场景目前 vite 构建时内联媒体资源的功能有 bug,从 2020 年底就已经存在一个 github issue,感觉短期不太可能解决,于是吾辈决定自行使用插件恢复这个功能。 下面是一个使用 vite 构建的 dist,可以看到其中的 svg 并未被正确内联到代码中,而是单独分割为了一个 bundle,而 jpg 图片则被正确内联。 现有插件为什么不使用插件 @rollup/plugin-im
前端使用工具强制实行代码规范(Vue) 场景 GitHub Demo 非强制性的规范都不会成为真正的规范。在之前,我们也会在团队内编写一些开发规范文档,却总是不能真正有效的执行下去,原因何在? 其一,人是健忘的,就算真正看完了规范文档,也不可能记住每一条规范,并且在代码中正确实践。 其二,人是懒惰的,即便有着规范,但只要写代码的时候没有强制性,那总是不会在意的。 那么,使用自动化的工具是为首选,而前端恰好有了一些可用的工具来帮助我
使用 ESBuild 插件机制实现需要的功能 前言esbuild 是一个通用的代码编译器和构建工具,使用 golang 构建,它非常快,性能上比现有的 js 工具链高 1~2 个数量级。它目前还不是一个开箱即用的构建工具,但通过它的插件系统,我们已经可以做到许多事情。 自动排除所有依赖项在构建 lib 时,我们通常都不希望捆绑依赖的模块,希望能够默认排除掉所有的依赖项,这个插件就是用来实现这个功能的。它会将所有不是以 . 开头的导入模块设置