Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
denoとtypescriptの関係について改めて考えてみる
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Kazuaki Higa
November 28, 2025
Technology
88
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
denoとtypescriptの関係について改めて考えてみる
TSKaigi Hokuriku 2025 13:00 〜 13:30 (toggleルーム)の発表に使用した資料です。
Kazuaki Higa
November 28, 2025
More Decks by Kazuaki Higa
See All by Kazuaki Higa
TypeScriptの「型」をAIのスキルに 昇華させてみた件について
higak9
1
610
NumPyの計算が速い理由をGIL解放のメカニズム観点でちょっとだけ掘り下げてみた
higak9
0
130
Other Decks in Technology
See All in Technology
Multi-Agent並列開発を 安全に回すための技術 / Technology for Safely Multi-Agent Parallel Development
tooppoo
0
180
“詰む”前に仕組みを作れ 〜技術の波に溺れないためのキャッチアップ術〜
takasyou
7
3.9k
AIに障害切り分けを全部やってもらった。 。 。 。
estie
0
160
いまさら聞けない「仕様駆動開発入門」 〜AI活用時代の開発プロセスを考える〜
findy_eventslides
2
200
不要なレビューをAIにまかせて AIコーディングの環境改善を加速した
shoota
1
270
秘密度ラベル初心者が第1歩でつまづかないための「設計・運用」ポイント
seafay
PRO
1
490
MySQL & MySQL HeatWave Report - June 2026
freshdaz
0
130
【2026年版】 ベクトル検索とEmbedding最前線
mocobeta
24
7.6k
【セミナー資料】Claude Code をセキュアに使うための考え方と設定の勘どころ / Claude Code Webinar 20260616
masahirokawahara
2
470
40代で“やっとエンジニアになれた”――閉じた学びを開き、空の青さを知る / 20260628 Naoki Takahashi
shift_evolve
PRO
4
880
自宅LLMの話
jacopen
1
720
Zenoh on Zephyr on LiteX
takasehideki
2
110
Featured
See All Featured
Impact Scores and Hybrid Strategies: The future of link building
tamaranovitovic
0
310
Thoughts on Productivity
jonyablonski
76
5.2k
More Than Pixels: Becoming A User Experience Designer
marktimemedia
3
450
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.7k
The browser strikes back
jonoalderson
0
1.3k
First, design no harm
axbom
PRO
2
1.2k
Context Engineering - Making Every Token Count
addyosmani
9
980
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
133
19k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
32
2.9k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
49
10k
Utilizing Notion as your number one productivity tool
mfonobong
4
330
Navigating the moral maze — ethical principles for Al-driven product design
skipperchong
2
400
Transcript
denoとtypescriptの関係について 改めて考えてみる 株式会社iimon 比嘉 一晃
X:@higakazuaki9 • 比嘉 一晃(ひが かずあき) • 沖縄県出身 • 株式会社iimon エンジニア ◦
不動産DXのツールを提供 https://iimon.co.jp/ • 現在の担当業務の技術スタック ◦ vanilla-tsやReact、Django、AWS、 Google Cloud(Firebase)...etc • これまでの経験 ◦ Angular、React、Vue.js、Spring Boot、Django、Fast API、Ruby on Rails…etc • 性格 ◦ 人懐っこい、面倒くさがり、ねことビー ル好き(お酒の失敗は、、、色々ありま す) プロフィール
株式会社iimon
はじめに 本日はDenoについて お話していきます ...
Denoってなに? モダンなWeb開発のための オープンソースな JavaScript Runtime by 公式サイト(https://deno.com/)
Deno ・v8、Rust、tokioをベースとしたJavaScriptおよびTypeScriptの実行環境 ・JSConf EU 2018にて、Node.jsの作者Ryan Dahl氏の講演「Design Mistake in Node」 の中で挙げられたNode.jsに関する10の反省点を踏まえ、公表
・2024年10月にメジャーバージョンが初めてアップデートされ V2となる Overview
Denoってなに? 特徴 • TypeScriptゼロコンフィグでサポート • npmとnodeのfirst-classをサポート • Web標準APIのサポート • 開発に便利なツールの提供
• セキュアな実行環境
Denoってなに? 特徴 • TypeScriptゼロコンフィグでサポート • npmとnodeのfirst-classをサポート • Web標準APIのサポート • 開発に便利なツールの提供
• セキュアな実行環境
TypeScriptゼロコンフィグでサポート Denoをダウンロード&インストール(豊富なインストール方法) Mac: Shell、npm、Nix、asdf、vfox、Cargo、Docker Windows: PowerShell、npm、Scoop、Choco、Winget、vfox、Cargo、Docker Linux: Shell、npm、Nix、asdf、vfox、Cargo、Docker →インストール後、バージョンを確認( v8やTypeScriptのバージョンも確認可)
Installation
Version Change TypeScriptゼロコンフィグでサポート upgradeコマンドでバージョンを変更( v8やTypeScriptのバージョンも変更)
initコマンドでDenoの プロジェクトを構築 TypeScriptゼロコンフィグでサポート Initialize Project
初期の構成はシンプル deno.jsonでプロジェクト管理 TypeScriptゼロコンフィグでサポート Initialize Directory
Greet TypeScriptゼロコンフィグでサポート TypeScriptを書いて即実行 →TypeScriptのインストールやtsconfig.jsonの セットアップは一切不要(すぐ動きます)
Denoってなに? 特徴 • TypeScriptゼロコンフィグでサポート • npmとnodeのfirst-classをサポート • Web標準APIのサポート • 開発に便利なツールの提供
• セキュアな実行環境
npmとnodeのサポート Denoのインストール時にローカルに npmのレ ジストリのキャッシュを構築 deno.jsonでimportmapも定義可 npm
npmとnodeのサポート node Denoをインストール時にローカルに node api のレジストリのキャッシュを構築 トップレベルでawaitも利用可
npmとnodeのサポート package.json package.jsonの読み込みもサポート npm importと混在している場合は deno install で依存を解消
Denoってなに? 特徴 • TypeScriptゼロコンフィグでサポート • npmとnodeのfirst-classをサポート • Web標準APIのサポート • 開発に便利なツールの提供
• セキュアな実行環境
Web標準APIのサポート Fetch Denoが提供しているusers apiをfetchしてみた
Web標準APIのサポート Web Worker Web Workerを起動&ファイルを読み込み →ログに出力 ファイル読み込みには Deno APIのreadTextFileを 使用
Denoってなに? 特徴 • TypeScriptゼロコンフィグでサポート • npmとnodeのfirst-classをサポート • Web標準APIのサポート • 開発に便利なツールの提供
• セキュアな実行環境
開発に必要なツール Lint Denoに標準搭載されている Lint deno.jsonでルールをカスタムするこ とも可能
開発に必要なツール Lint Lint Error ・remove constructor(nothing super) ・super before using
this ・use const insteed
開発に必要なツール Test Denoに標準搭載されている Test JSRのパッケージも利用しつつ、手 軽にテストすることが可能 JSRとは... モダンなJS、TS開発のためのオー プンソースなパッケージレジストリ by
公式サイト: https://jsr.io/
開発に必要なツール Standalone Executable Deno.server APIで簡単なAPIの処理を書いてコ ンパイル
開発に必要なツール Standalone Executable コンパイル後のファイルを実行して サーバーにアクセス
開発に必要なツール Formatter Denoに標準搭載されている Formatter deno.jsonでルールをカスタムすることも可能
開発に必要なツール Formatter fmtコマンドでフォーマットの実行 エディタの設定でSave on Formatも可
Denoってなに? 特徴 • TypeScriptゼロコンフィグでサポート • npmとnodeのfirst-classをサポート • Web標準APIのサポート • 開発に便利なツールの提供
• セキュアな実行環境
セキュリティ Security Denoはデフォルトでファイル実行時にセ キュリティチェックが入る
セキュリティ Security ・ ・ ・ オプションをつけずにそのまま実行する とセキュリティチェック対象の項目の許可 を求められる
セキュリティ Security 拒否すると処理されずに終了する
セキュリティ Security --allow-all(または-A) 全ての権限を許可 --allow-read ファイル読み込みの許可 --allow-write ファイル書き込みの許可 --allow-net ネットワークへのアクセス許可
--allow-env envへのアクセス許可 …etc オプションをつけることで許可の チェックを省略できる
Denoってなに? 特徴 • TypeScriptゼロコンフィグでサポート • npmとnodeのfirst-classをサポート • Web標準APIのサポート • 開発に便利なツールの提供
• セキュアな実行環境 • 豊富なDeno CLI • トップレベルでのawait(async不要) • Deno APIを活用した効率的な開発 • Deno.jsonによる柔軟なプロジェクト管理 • JSRなどのモダンなパッケージの活用 モダンな TypeScriptの開発体験を 手軽にセキュアに提供
Denoで何をしよう 例えば... Web開発をしてみる
Vite-React with Deno Project Initialize and Build Viteを使ったReactプロジェクトの 構築をDenoで実施
Vite-React with Deno Server Start 開発サーバーを立ち上げて いつものHello React
Vite-React with Deno Custom App Appをカスタム Hooksなどを使っていつもの感じの Reactで開発
Vite-React with Deno Directory ディレクトリ構成もいつもの Vite-Reactプロジェクトと同じ感 じ →package.json、tsconfig、 vite.configなど
Denoで何をしよう 例えば... AIを活用した CLIを作ってみる
CLI Tool with Gemini API Weather App Gemini APIとdaxを使ってお天 気アプリを作成
CLI Tool with Gemini API Install and Exec deno installのnameオプションで名前をつ
けてCLIとして保存できる
Denoで何をしよう 例えば... データ分析してみる
Jupyter with Deno Setup Jupyter VSCode Jupyter extension https://marketplace.visualstudio.com/items?itemName=ms-toolsai.jupyter DenoでJupyter
Notebookを利用 するためのセットアップ
Jupyter with Deno Select Kernal DenoのKernelが選択できる
Jupyter with Deno Hello Jupyter Jupyter上でTypeScriptが動く
Jupyter with Deno penguins ちゃんとDataFrameが型付けされていることを確認 ペンギンデータで遊んでみる
Jupyter with Deno penguins headやtoRecodesなど基本的 なDataFrameの関数も利用可
Jupyter with Deno penguins dropNullsなどの欠損値補完 やdescribeでの集計データの 確認なども可能
Jupyter with Deno penguins Plotでデータをプロット
Jupyter with Deno penguins Plotでデータをプロット 基本的なデータ分析は十 分にできそう
まとめ Denoの使いどころ ・npm、Nodeとの互換性を活かしたプロジェクトの刷新 ・AIを利用したツール類の量産( MCP Toolなどとの連携) ・よくわからないコードをセキュアに実行 (特に生成AIで出されたものなど) ・TypeScriptを利用したスムーズなデータ分析 …etc
まだまだ方向転換などはあるかも
Appendix
Appendix ・デプロイまわり https://deno.com/deploy ・Fresh(Deno推しのシンプルWebフレームワーク) https://fresh.deno.dev/ ・WebAssembly https://docs.deno.com/runtime/reference/wasm/ ・Deno API Reference
https://docs.deno.com/api/deno/ ・Deno標準ライブラリ https://docs.deno.com/runtime/reference/std/ Denoにまつわる情報のリンク集
ご清聴ありがとうございました!