Denoが新フレームワーク「Fresh 1.0」リリース。Just-in-timeレンダリングやランタイムオーバヘッドゼロなどの特徴がもたらす優位性とは?

今回は「Denoが新フレームワーク「Fresh 1.0」リリース。Just-in-timeレンダリングやランタイムオーバヘッドゼロなどの特徴がもたらす優位性とは?」についてご紹介します。

関連ワード (構築、直結、要求毎等) についても参考にしながら、ぜひ本記事について議論していってくださいね。

本記事は、Publickey様で掲載されている内容を参考にしておりますので、より詳しく内容を知りたい方は、ページ下の元記事リンクより参照ください。


JavaScriptやTypeScriptのサーバサイドランタイム「Deno」を開発するDeno Land Inc.は、Deno用のフルスタックフレームワーク「Fresh 1.0」のリリースを発表しました。

バージョン番号の1.0が示すように、安定版としてのリリースです。

Fresh is a new full stack web framework for Deno. It sends zero JavaScript to the client by default and has no build step. Today we are releasing the first stable version of Fresh.https://t.co/WV2C6gllsL

— Deno (@deno_land) June 28, 2022

Freshは以下の特徴を持つと説明されています。

  • エッジでのJust-in-timeレンダリング
  • ビルドの工程が不要
  • デフォルトではクライアントにJavaScriptを用いないため、ランタイムオーバーヘッドがゼロ
  • 高いインタラクティブ性を実現するためアイランドベースのクライアントハイドレーションを採用
  • コンフィグレーション不要
  • TypeScriptをサポート

これらの特徴がFreshにどのような優位性をもたらすのでしょうか。

要求毎にHTMLをレンダリング。ビルド工程不要

Freshは、基本的にはすべてサーバサイド側でHTMLが生成されます。Freshの基礎部分はテンプレートエンジンとルーティングフレームワークであり、これが1つ目の特徴である「エッジでのJust-in-timeレンダリング」を実現しています。

ちなみにDeno LandはDenoをCDNのエッジロケーションで提供するサービス「Deno Deploy」を提供しているため、サーバサイドではなくあえて「エッジ」という言葉を使っているのだと推察されます。

エッジでのJust-in-timeレンダリングとは、要求が発生したタイミングでレンダリングを行い、HTMLを生成する、という意味です。これは2つ目の特徴である「ビルドの工程が不要」とも直結しています。

サーバサイドでHTMLを生成する場合、あらかじめビルドを行うことでHTMLファイルを生成しておくことで、Webブラウザから要求があった時点で生成済みのHTMLをすぐに返すことができる高速性を実現できます。ただしこの場合、デプロイする毎にビルド工程が発生するため、リリースサイクルが遅くなりがちです。

Freshでは要求毎にJust-in-timeレンダリングを行うことで事前のビルド工程を省略しました。これは事前にHTMLを生成する仕組みよりもWebサイトのレスポンスが多少犠牲になりますが、それ以上にFreshがリリースサイクルの高速さを重視しているといえるでしょう。

サーバサイドでHTMLを生成、クライアント側のJavaScript不要

クライアントとなるWebブラウザ側ではデフォルトでJavaScriptを用いないことも、Freshの大きな特徴です。

従来のWebアプリケーションの多くで用いたれていたSPA(Single Page Application)と呼ばれる仕組みでは、WebブラウザにJavaScriptフレームワークを送信、実行して、サーバ側から送られたデータを基にDOMを生成し、Webページが表示されるという処理が行われていました。

FreshではサーバサイドでHTMLが生成され、それがWebブラウザに送られてくるため、Webブラウザは受け取ったHTMLをすぐに表示できます。これが3つ目の特徴である「ランタイムオーバーヘッドがゼロ」です。

ただしこれではWebブラウザ上でインタラクティブなユーザーインターフェイスには不向きです。

そこで登場するのが4つ目の特徴である「高いインタラクティブ性を実現するためアイランドベースのクライアントハイドレーションを採用」です。

インタラクティブなWebページの機能も組み込める

Freshはアイランドアーキテクチャを取り入れています。

アイランドアーキテクチャを簡単に説明するならば、Webページのヘッダやフッタ、サイドバーなどインタラクティブ性が必要なく、固定されたレイアウトとデザインを持つ部分のHTMLは、あらかじめサーバサイドで生成して静的HTMLとしてWebブラウザに送信して表示しつつ、インタラクティブ性が必要となる部分のJavaScriptは必要に応じて後から組み込む(ハイドレーションする)、という仕組みのことです。

Freshではこのインタラクティブ性を組み込む部分のJavaScriptフレームワークとしてPreactとJSX/TSXに対応しています。

これにより、WebブラウザでのランタイムオーバーヘッドなしにWebページの高速表示が可能な利点をできるだけ活かしつつ、インタラクティブなユーザーインターフェイスにも対応することを実現します。

FreshはDenoの代表的なフレームワークに

DenoはもともとNode.js作者のライアン・ダール氏が、Node.jsでの反省を活かして新たに開発したJavaScript/TypeScriptランタイムでした。そのDenoは、フレームワークにおいても、既存のさまざまなフレームワークを見直してDeno(そしてDeno Deploy)にふさわしいものに作り直した、それがFreshなのかもしれません。

すでにDeno LandのWebサイトの多くがFreshで構築されているとのことです。今後FreshはDenoの代表的なフレームワークとなっていくと予想されます。

COMMENTS


Recommended

TITLE
CATEGORY
DATE
ライフログアプリSilentLogを提供するレイ・フロンティアが個人ユーザー・自治体・企業に向け防災機能をリリース
IT関連
2022-03-12 20:09
IT系上場企業の平均年収を業種別にみてみた 2023年版[後編] ~ パッケージソフトウェア系、SI/システム開発系、クラウド/キャリア系企業
働き方
2023-07-19 04:11
ビズリーチ、クラウド勤怠管理システム「HRMOS勤怠」を提供
IT関連
2022-02-17 03:16
コンピュータービジョンを利用した誰でも使いやすいビデオエフェクトの動画エディターVOCHIが全世界的に人気
ソフトウェア
2021-07-24 19:28
「Windows 10」の「EcoQoS」機能、バッテリー持ち改善やファンノイズ低減を可能に
IT関連
2021-04-26 09:28
増加するQRコードを悪用したフィッシング–難読化や検知回避の手法も
IT関連
2024-01-10 00:06
2023年のITサービスベンダー売上ランキング、NECと日立が逆転
IT関連
2024-07-14 23:54
ブラウザの拡張機能で商品購入時のカーボンオフセットを提案するEcoCartが約3.3億円調達
EnviroTech
2021-04-14 05:20
Microsoftの「Azure」などが“政府認定クラウド”の仲間入り セキュリティ評価制度「ISMAP」に登録
クラウドユーザー
2021-06-24 05:07
Googleの親会社Alphabet、ロボット用ソフト企業Intrinsic立ち上げ
企業・業界動向
2021-07-26 13:12
オフィス再開に向けて大手テック企業はそれぞれ柔軟なワークモデルを検討中
パブリック / ダイバーシティ
2021-06-13 01:52
エポスカードかたる詐欺メールに注意 偽の会員サイトでクレカ情報など窃取
セキュリティ
2021-01-27 15:48
保険の営業先、AIが提案 顧客データ解析 朝日生命
DX
2021-07-28 00:00
パンデミック後のアフリカのモバイルアプリ市場と急上昇するモバイルゲームアプリ利用率を読み解く
ソフトウェア
2021-07-30 14:24