学习 - 使用 FastAPI+aiosqlite+databases 搭建服务端的基础用法
说明
本文是主要为从未使用过这些框架的人做一个介绍,并没有太多的技术含量。
连接池
首先先把我最焦虑的问题放在这里,到底要不要一个连接池?
我在 aiosqlite 的仓库中搜到了这样一条 issue,作者为我们介绍了为什么使用 sqlite 数据库时连接池不是那么重要。我并没有说它不重要,只是在轻量级使用中可以不在意这点。我这里把原文复制过来,并且把重要句子标粗。
Generally spea ...
开发 - 异步加载 Vue 组件以减小 chunk 体积
问题
当你的组件过于复杂时,这里指它引用了非常多的第三方库,那么当你打包的时候或许会碰到下面的警告:
1234(!) Some chunks are larger than 500 KiB after minification. Consider:- Using dynamic import() to code-split the application- Use build.rollupOpti ...
开发 - Python 使用 pkgutil 访问包内资源
结论
pkgutil 是 python 的内置模块,可以用来打开包内文件。
使用的时候如下:
123456import pkgutildef foo(): data: bytes = pkgutil.get_data(__name__, 'file.txt') content: str = data.decode('utf-8') prin ...
学习 - Python + inspect 一行实现递归 fib 函数
背景
有个裙友要看看用 lambda 能不能在一行里定义出来 fib 函数,并且不要那个根号五的数学公式,于是就有了这篇文章。
介绍
inspect 库可以帮助我们拿到 Python 上下文的各种信息,自然也包括了当前正在运行的函数。配合 eval 可以达到我们的目的。
实现
原始方法
虽然大家都知道,但还是放上来做一个对比。
1234567def fib(n): if n in (1, 2 ...
开发 - Vue Router 搭配 NaiveUI 的进度条
介绍
由于 naive ui 的进度条需要依赖于一个 NLoadingBarProvider,所以我们在定义 router 的时候是无法使用 useLoadingBar() 获取到进度条对象的。
我的解决方法是利用 pinia 把 loadingBar 示例获取到,然后存起来,这样就可以访问到了。
这里用 pinia 的原因单纯是因为它简单好用,并且还能在浏览器插件里看到变量的值,而单纯的全局变量 ...
开发 - 记一次 Nginx 调试
背景
一般来说 Nginx 使用起来挺简单,不出意外的话应该没什么问题,但今天我就出意外了。
我的配置很简单,如下:
123456789server { server_name www.hikariyo.net; root /web/www; index index.html; location / { try_files $uri $uri/ =404; ...
开发 - 迁移 VPS 到 Vultr
为什么要迁移
趁着中秋节之前总算是把我的 VPS 迁移到了 Vultr,域名也换了一个 .me 结尾的,更有个人网站的感觉,但是一年下来也得多花不少钱,疼死我了。
我以前是全套阿里云,服务器是他的,域名也是从他那里买的。不是说阿里云不好,但是对于我这种小小的个人网站来说,他的价格有点高,没有活动最低配置是七八百。
而且,由于某些众所周知的原因,管得比较严。做很多事情都要去报备,着实比较烦心。
迁移 ...
学习 - JS 实现函数重载
需求
假设我们有这样一个数据(来源于参考文章中的浅谈JavaScript函数重载,链接在文章尾部给出):
123const users = { values: ["Dean Edwards", "Alex Russell", "Dean Tom"]}
要定义一个find方法,使得它可以在下列三种情况工作:
当不 ...
开发 - Nginx 自定义错误页面
打开配置文件,找到你想自定义错误页面的location块:
1234location / { error_page 404 /404.html; # 其它配置}
确保你有404.html这一文件,如果还想捕捉更多错误,可以这样写:
1error_page 404 403 500 /error.html;
这样就完成了,不用再看经典的Nginx默认错误页面了。
学习 - 原生 JS 实现哈希路由
源码
使用Codepen在线体验和查看源码。
页面代码
在我们用前端框架的时候,经常用到路由技术,就是在地址栏确实发生了变化但是页面没有刷新,那么本文就介绍通过更改哈希的方式实现这样一种路由,下面是页面代码:
123456789<h1>Hash Router</h1><div> <a href="#/">Home</a ...