この記事はCode Chrysalis Advent Calendar 2019の記事です。
はじめに
こんにちは!
CodeChrysalisのイマーシブブートキャンプに参加中のえりこです
私はCode Chrysalisに入って初めてReact&Vue.jsを触ったのですが、
初学者の私には混乱の連続でした。。
今日は私の混乱の1つである
「React, Vue.js はフレームワーク?ライブラリ?」問題について
私なりの見解を書こうと思います。
React, Vue.js はフレームワーク?ライブラリ?
Reactは、JavaScriptライブラリー。
Vue.jsは、JavaScriptフレームワーク。
...
- ライブラリとフレームワークって何が違うんだろう?
- ReactもVue.jsも似てるけど、なんでReactはライブラリーでVue.jsはフレームワークなんだろう?
そんな疑問が頭の中をぐるぐると巡らせました
ライブラリーとフレームワークの違い
現時点での私の理解をまとめてみます。
(ご意見などあればコメントいただけると嬉しいです!)
フレームワーク
アプリケーションを動かすために必要な処理・機能が一通り実装されている。
その他に必要な処理などがあれば自分で実装して、フレームワークに組み込んで利用することができる。
開発者が一からフルスクラッチで作るのは大変だけど、フレームワークを利用することで、楽するとこは楽してコアな部分にフォーカスすることができる、というイメージ。
JavaScriptフレームワークの例
Vue.js、AngularJS、Bootstrap
ライブラリ
いろいろな便利な機能が準備されていて、必要に応じて必要な機能のみをピックアップして利用する。
主体はライブラリではなく、主体のプログラムから呼ばれて使われる。
JavaScriptライブラリの例
React、jQuery、Node.js、D3
例えて言うと...
料理を作る時を想像してみましょう
必要な基本的な具材が最初から揃っているような、「パルシステムのお料理セット」のようなものがフレームワーク。
煮干しや昆布から出汁を取る手間を省いてくれる「だしの素」とか、料理を楽にしてくれる「簡単に調理できる鍋」とか、ヘルシオみたいな「ハイテク家電」がライブラリー。
...うまく想像できましたか??
参考にさせていただいたサイト
- ソフトウェアフレームワーク(Wikipedia)
- ライブラリ(Wikipedia)
- フレームワークとライブラリの違い(Qiita @azuki8)
- 「ライブラリ」と「フレームワーク」は何が違うのか(Qiita @baby-degu)
Reactはライブラリーで、Vue.jsはフレームワーク?
ライブラリーとフレームワークの違いがわかったところで、
次はReactとVue.jsについて考えてみます。
感覚的にjQueryがライブラリーって言うのはわかるけど、
Reactってフレームワークじゃないの?という疑問を抱きました。
だって、ライブラリーと言うにはあまりにも機能が充実し過ぎているし、React単体でも十分いろいろ作れるし
同じ疑問を持つ人は私だけでなく世界中にいるようです
GoogleでIs React library or a framework?
と検索してみると
似たような質問をしている人がたくさんいます。
私が通うCode Chrysalisでも同様の疑問を持つ人はいましたが、
みんなと話したり、調べたりした結果の私の理解を下記に記載します。
Reactはライブラリー
ReactはFacebookが提供しているが、多くの有名なReactライブラリーは
3rd partyライブラリーとして提供されている。
例えば、
- 状態管理:
redux
(Dan Abramov氏, Andrew Clark氏) - デザイン:
MaterialUI
(Google) - テスト:
Enzyme
(Airbnb)
アプリケーション全体をオーガナイズするものを一般的に"フレームワーク"と呼ぶが、
上記で説明したように、Reactはアプリケーションに必要な機能がReact本体(Facebook)以外からたくさん提供されており、もはやReact単体では利用するのは難しい。
だからReactはフレームワークではなくライブラリーだ!
という主張でしょうか。
Vue.jsはフレームワーク
一方で、Vue.jsは ReactのようにVue.js単体で使うには物足りないかもしれないが、
Vue.jsが公式ライブラリーとしてたくさんの機能を提供している。
例えば・・・
- 状態管理:
vuex
- デザイン:
vueify
- ルータ機能:
Vue Router
- ブラウザ拡張機能(Chrome/Firefox):
vue-devtools
- ESLintプラグイン:
eslint-plugin-vue
※他にもいろいろあるので、興味がある方はこちらをご覧ください。
https://github.com/vuejs
Reactと比べて、Vue.jsは公式ライブラリーだけでアプリケーションを動かす最低限の機能が整っていそうです。
Vue.js単体でということではなく、公式Vueチーム全体として、Vue.jsはフレームワークだ!という主張なのかな??
まとめ
個人的にはまだReactはライブラリーと言うのに100%納得している訳ではないですが、
いろんな人の意見を聞いたり自分で考えたりして思ったことは、
**ちゃんと理解してしっかり自分の意見を持つことが大事。**ということ。
別にReactがフレームワークだ!っていう意見でも、
Vue.jsがライブラリーだ!って意見でもいいと思うんですよね。
ただ、なんで?って聞かれた時に
しっかり自分の意見が言えるかどうかが重要なんじゃないかなって思います。
(その意見がチンプンカンプンだったらアレですけど... ^^;)
みなさんのご意見やコメントもいただけると嬉しいです