社内向けに、フロントエンド関連のニュースや業務で発生したQ&A、利用しているライブラリなどの情報を定期的に書いています。
社内の開発部メンバーに向けて直近でリリースされたライブラリなどの情報をMatsuri-tech Frontend Weeklyとしてまとめています。内容は実務や趣味で使えそうなものを中心に扱っており、網羅的ではなく偏りがあります。
2023年11月20日にTypeScript 5.3がリリースされました。
新たな構文のサポートに加えて、JSDoc解析をスキップすることによる最適化やパッケージの重複を避けることによるパッケージサイズの削減なども行われました。
Stage 3のImport Attributesがサポートされました。
これによりモジュールの形式をランタイムに提供できるようになります。
import obj from "./something.json" with { type: "json" };
import * as foo from "./foo.js" with { type: "fluffy bunny" };
const obj = await import("./something.json", {
with: { type: "json" }
});
switch (true)
内の各case
句に基づいて型の絞り込みをできるようになりました。
function f(x: unknown) {
switch (true) {
case typeof x === "string":
// 'x' is a 'string' here
console.log(x.toUpperCase());
// falls through...
case Array.isArray(x):
// 'x' is a 'string | any[]' here.
console.log(x.length);
// falls through...
default:
// 'x' is 'unknown' here.
// ...
}
}
true
または false
と直接比較した場合でも、絞り込みが出来るようになりました。
interface A {
a: string;
}
interface B {
b: string;
}
type MyType = A | B;
function isA(x: MyType): x is A {
return "a" in x;
}
// <=5.2
function someFn(x: MyType) {
if (isA(x)) {
console.log(x.a); // works!
}
}
// <=5.2
function someFn(x: MyType) {
if (isA(x) === true) {
console.log(x.a); // not works
}
}
// 5.3
function someFn(x: MyType) {
if (isA(x) === true) {
console.log(x.a); // works!
}
}
2023年11月20日にGit 2.43がリリースされました。
リバートコミットをリバートした際のコミットメッセージのRevert RevertからReapplyになりました。
$ git revert --no-edit HEAD >/dev/null
$ git revert --no-edit HEAD >/dev/null
$ git log --oneline
- a300922 (HEAD -> main) Revert: "Revert: "fix bug""
+ a300922 (HEAD -> main) Reapply "fix bug"
0050730 Revert "fix bug"
b290810 fix bug
巨大なリポジトリを扱う際に、Blobを必要に応じて取得するBlobless cloneを実行したい場合があります。
git clone --filter=blob:none git@github.com:git/git.git
これを通常のローカルリポジトリに後から適用できるようになりました。
% git repack -ad --filter=blob:none --filter-to=pack --no-write-bitmap-index
% git config remote.origin.promisor true
% git config remote.origin.partialclonefilter blob:none
他にも1MiB 未満の Blob のみフィルタリングして取得するといったことも出来ます。
git repack -ad --filter='blob:limit=1m' --filter-to=pack
2023年11月21日にFirefox 120.0がリリースされました。
トラッキングコードを削除したリンクをコピーする機能が追加されました。またWebAssembly GCが有効になりました。