Node.jsで学ぶWebシステムとソフトウェア開発基礎!Node.js完全入門ガイド

本コースではNode.jsの基礎に加え、Webシステムの仕組み、デスクトップアプリ開発、自動化ツールの作成方法、フロントエンドツール界隈のトレンドなどについて学ぶことができます!Node.js周りの知識はこれ一本でバッチリです!!

4.64 (576 reviews)
Udemy
platform
日本語
language
Web Development
category
Node.jsで学ぶWebシステムとソフトウェア開発基礎!Node.js完全入門ガイド
6,167
students
18 hours
content
Apr 2024
last update
$59.99
regular price

What you will learn

Nodejsの基礎から応用例まで網羅的にマスターすることができます。

Nodejsとブラウザ環境でのJavaScriptの挙動の違いについてマスターすることができます。

npmの挙動や便利コマンドを学ぶことができます。

Nodejsを用いた自動化プログラムを構築する方法について習得することができます。

Playwrightを用いたスクレイピングの手法について学ぶことができます。

フロントエンド開発界隈の現状とトレンドについて学ぶことができます。

Webpackとは何か?また、Webpackを含めたフロントエンド開発で使用するビルドツールについて学ぶことができます。

Nodejsを使ったバックエンド開発の手法について習得することができます。

ブラウザとサーバー間の通信の基本的な仕組みについて学ぶことができます。

Webシステムで広く用いられているRest APIの実装方法について学ぶことができます。

MongoDBを用いたバックエンド開発を学ぶことができます。

ReactとRest APIを使った実践的なアプリケーションの構成について学ぶことができます。

作成したアプリケーションをインターネット上に公開する方法について学ぶことができます。

Electronを用いたデスクトップアプリの構築方法について学ぶことができます。

デスクトップアプリを実際にビルドし、配布する方法について学ぶことができます。

Why take this course?

Webエンジニアを目指している方

Node.jsを使ってフロント側のコードの実装を行っている方

フロントエンドツール界隈の技術がカオスすぎて混乱している方

VueやReactなどのSPAライブラリを学んでいる方

モダンなWeb開発の全体像をとらえたい方

JavaScriptで何か動くものを作ってみたい方

デスクトップアプリの開発などに興味のある方

プログラムを使った自動化の技術に興味のある方

JavaScriptやフロントエンドの学習をしている方


これらに当てはまる方は是非こちらのコースを受けてみてください。本コースでは、ただNode.jsについて学ぶだけでなく、Node.jsを中心としたモダンな開発の手法について網羅的に学んでいきます。



- Node.jsって何?

Node.jsは世界で最も使用されているプログラミング言語のJavaScriptを実行するための環境です。元々は2009年にJavaScriptを用いたサーバーサイドのプログラムの実行環境として開発されました。ただ、それから10年以上の月日が経ち、昨今のNode.jsはサーバー上の処理を実装するためだけではなく、ソフトウェア開発の様々なシーンで利用されています!


- Node.jsを学ぶメリットは?

Node.jsは昨今のWeb開発、ソフトウェア開発のいたるところで使用されています。特にフロントエンド側の開発を行っている場合、Node.jsは必ずと言っていいほど使用します。また、PaypalやLinkedInといった大企業はバックエンドにNode.jsを導入しています。それに加えて、デスクトップアプリの開発モバイルアプリの開発などもNode.jsで行えます。プログラムは全てJavaScriptで書くことができるため、様々なことを一つで出来るかなりコスパのいい技術になります!


- Node.jsって難しいの?

Node.jsはJavaScriptが出来れば誰でもできます。ただ、使いこなせるようになるにはNode.js独特のルールについてマスターする必要があります。JavaScriptが実行できる環境にブラウザがありますが、ブラウザ上で実行された時とNode.js上で実行された時ではJavaScriptの動作が異なります。本コースではそういった違いなどについても体系的に解説していきます!


- 本コースで学ぶこと!

本コースで学ぶことについて以下にまとめました!興味のある方は是非一度ざっと見てみてください。


- 本コースで学ぶこと - ポイント1(Node.js基礎)

本コースでは、まずはターミナル上での基本的なコマンドの使い方から学んでいきます。また、パスの取り扱いについても何となく理解している方も多いと思いますので、本コースでマスターしていってください。普段、何気なく使っているNode.jsの使い方と特徴についてはブラウザ環境と対比しながら説明しますので、違いが明確になり頭の中がすっきりすると思います!


・Node.jsのバージョンの意味。

・Node.jsの実行方法。

・PC上のパスの取り扱い方法について。

・ターミナルの基本的な使い方。

・モジュール管理システム(CJS / ESM)。

・ブラウザ環境とNode.js環境の違い。



- 本コースで学ぶこと - ポイント2(npm基礎)

Node.jsの基礎が終わったら、npmについて学びましょう。npmはNode.jsのパッケージ管理のためのツールです。

npmでインストールしたパッケージはNode.js上で自由に使用することができますが、意外とその仕組みは理解していないもの。基礎を固めることによって、エラーなどにも対処できるようになりましょう!


・npmってなに?npmを使う理由。

・package.jsonの中身を見る!

・npmの便利コマンド紹介!

・パッケージ読み込みと実行。

・npm install使いこなせてる?

・コマンド型のパッケージの仕組み!

・グローバルパッケージの管理方法など。



- 本コースで学ぶこと - ポイント3(自動化ツールの作成)

基礎が完了したら、実際にコードを書いてみましょう!本コースではPlaywrightというライブラリを用いて、サイト内の情報を取得し、Google Spread Sheetに書き込んでみます。プログラムの定期実行やその結果のEmail送信なども行いますので、楽しみにしてください!


・サイトの情報を自動で収集!

・収集した情報をcsvに出力。

・Google Spread Sheetと連携して出力!

・定期実行も可能!

・エラーが起きた時の処理の記述。

・Emailで結果の通知!



- 本コースで学ぶこと - ポイント4(モダンフロントエンド開発界隈の現状把握)

昨今のフロントエンド開発はかなりカオスな状況です(いや、ホントに)。特にフロントエンドのコードをビルドするためのツールなどは乱立しており、初心者の方からしてみれば何を使うべきなのか?何を学習するべきなのか?が分からないと思います。

本コースでは初心者の方が知っておくべき、フロントエンド界隈の知識について体系的に説明していきますので、効率的に最新のトレンドをキャッチアップすることができます。


・モジュールバンドラーって?トランスパイラとは!?

・用語やツールについて説明。

・現状とトレンドについて説明。

・良く使用されるツールの用途について。

・webpackを例に設定方法の意味を解説。

・最新のビルドツールViteについて紹介!



- 本コースで学ぶこと - ポイント5(バックエンド開発)

フロントの学習が終わったら、次はバックエンドの実装について学んでいきましょう!バックエンドを学ぶということはすなわちWebシステムの仕組みを学ぶ必要があります。Webシステムの仕組みを知れば、他のプログラミング言語でバックエンド側の実装を行った時もとても役に立ちます。(プログラミング言語による違いは書き方の違いのみで、Webシステムの仕組みはどの言語でも同じです。)本コースではRest APIを作りながら、Webシステムの基本的な仕組みと実装方法について学習していきます!


・Webページが表示されるまで!

・サーバーとブラウザのやり取り!

・Content-Type?HTTPステータス?

・POSTとGETメソッドの違い?送り方と受け取り方。

・Rest APIについて学ぶ!application/json?

・ルーター?ミドルウェア?サーバーの基本を習得!

・MongoDBにデータを格納!



- 本コースで学ぶこと - ポイント6(モダンなWebアプリの構築)

バックエンドの実装が完了したら、今度はフロントエンドのコードと統合して、画面を持ったアプリケーションを実際に構築してみましょう。フロントエンド側はReactを用いたSPA(Single Page Application)を用意しています。Reactの実装や細かな説明は行いませんが、実際どのようにしてWebシステムが構成されているのかを具体的に知ることは大変勉強になると思います。また、作成したアプリケーションはインターネットへの公開まで行いますので、ポートフォリオを公開したい人などは是非楽しみにしてください。


・フロントエンドのコードとバックエンドのコードの統合。

・CORS制約とは?

・どのようにWebアプリは動くのか?

・インターネットへの公開。



- 本コースで学ぶこと - ポイント7(デスクトップアプリ開発)

最後に、デスクトップアプリの開発をやってみましょう。実は皆さんが普段お使いのアプリにもNode.jsで開発されたものはたくさんあります。例えば、VSCode、Teams、Slack、Discord、SkypeなどはNode.jsのライブラリであるElectronで作成されています。本コースでは実際にElectronを用いて、画像ダウンロードアプリを作成し、それを配布できる状態にビルドまでします。また、コースの最後にはReact Native + Expoを用いたスマホアプリ開発のための環境構築の方法についても紹介しますので是非楽しみにしてください。


・Electronって何?

・Electronを使ったアプリの特徴。

・プロセスってなに?

・IPC(プロセス間通信)とは!

・画像ダウンロードアプリを作成!

・アプリを実際にビルドして配布!

・Node.jsでスマホ開発!


以上が本コースでざっと学ぶことになってきます。


もし、あなたがJavaScriptを使った開発に興味があれば、是非一度Node.jsについて学んでみてください。Web開発のスキルアップはもちろん、Webシステム以外のプログラムも行うことができるようになるため、JavaScriptを使った開発の幅がグッと広がります!


また、近年ではDenoやBunといったNode.js以外のJavaScript実行環境も登場してきていますが、Node.jsを習得すればその他の実行環境についても特に問題なく使用することができます。


是非この機会にNode.jsに触れてみてください!



5. 本コースで使用する代表的なパッケージ

express: 4.18.1

mongodb: 4.10.0

mongoose: 6.6.1

webpack: 5.74.0

babel: 6.23.0

google-spreadsheet: 3.3.0

node-cron: 3.0.2

playwright: 1.27.1

node: 18.12.1

nodemailer: 6.7.8

vite: 3.2.0

react: 18.0.22

react-dom: 18.0.7

electron: 20.1.4

electron-builder: 23.6.0

npm-run-all: 4.1.5

chrome-paths: 1.0.1

image-downloader: 4.3.0

expo-cli: 6.0.8


その他)

WSLを用いて学習を進めたい方へ。

WSL(Windows Subsystem for Linux)を用いてもNodeは実行可能なため、受講いただくことはできますがセットアップや一部動画の通りにコマンドが流れない可能性があります。(パスが通っていないためエラーになるなど。)そのため、WSLを用いて本コースを受講する場合にはその点をご留意いただけますと幸いです。

Screenshots

Node.jsで学ぶWebシステムとソフトウェア開発基礎!Node.js完全入門ガイド - Screenshot_01Node.jsで学ぶWebシステムとソフトウェア開発基礎!Node.js完全入門ガイド - Screenshot_02Node.jsで学ぶWebシステムとソフトウェア開発基礎!Node.js完全入門ガイド - Screenshot_03Node.jsで学ぶWebシステムとソフトウェア開発基礎!Node.js完全入門ガイド - Screenshot_04

Reviews

とれ
October 4, 2023
自分はフロント寄りの人間でバックエンド側の実装をやったことがなく、学習の機会にと思いレクチャーを購入しました. nodejsにおけるAPIサーバの構築、バックエンド実装の流れを掴むことができます。独学ではなかなか身につかないお作法や勘どころも含めて教えてくださるので助かります。 曖昧になっていたcommonJSとESModuleの違いもよく分かりました。 CodeMafiaニキ特有の大ボリューム(大サービスでもある)で、ハードでは有りましたが、非常にためになりました。
Shingo
July 17, 2023
大満足です。 Node.js、npm、ビルドツールの充実した内容を始め、Playwright、Express、REST API、MongoDB、React、Electron などなど、 色々なことが経験できたので本当に良かったし、Node.js は色々なことができて楽しいですね。 ※最後の Expo だけはデスクトップ PC とスマホが別ネットワークなため実践できず。。 JavaScript 自体ちゃんと勉強したのが初めてでしたが、早速仕事でバンバン使って行きたいと思います。
Pereira
June 26, 2023
このコースはプレビュー動画をすべて見終わったうえで購入を決めました。これまでJavascriptはDOM操作レベルで使用してきましたが、もっともっと深入りして、いろんなもの作って、最終的には障碍者でほぼ家から出ない自分の本業にしたいと思っています。サーバやデスクトップアプリ、そしてスマホアプリが作れることからnodejsにはすごく魅力を感じています。PHPでMySQLと接続してデータのやり取りはできますが、nodejsからデータベースとのやり取りができるようになりたいこともあってこの講座に飛びつきました。よろしくお願いします。
suzu-ki
June 20, 2023
codemafia先生のJavaScript講座から、React講座を経てNode.js講座を受講してきたことで、JavaScriptを最大限活用できる方法を体験することができました。とてもわかりやすく、快適に学べて楽しかったです。
Okua
December 3, 2022
スクレイピングやアプリの制作を通してNode.jsを学べるのでかなりいい教材だと思いました。 npmなど触れる機会は多いが、どういったものなのかいまいちピンと来なかったり、毛嫌いしてしまう人が多いかと思うので、この辺りを学べるのはかなりのポイントかと思います! まだ前半部分までしかしてないので、後半部分であれば申し訳ないですが、サーバーサイドを意識したリアルタイムWebアプリケーション(websocket)やマルチプロセス、マルチスレッド、EventEmitterなども盛り込まれていれば満足です。 なければ今後の追加を期待しております。 JavaScriptの基本に関しては同じcode mafiaさんのJavaScriptのメカニズムで学べばかなり深く学べるのでそちらの教材と合わせて学べはよりJavaScriptへの理解が深まるかと思います。 是非ともTypeScript、Vueに焦点を当てた教材も今後発売されることを密かに期待しております。
Ryo
November 19, 2022
Node.jsを使った開発手法に関してざっと学べるコースです。コースの解説にある「フロントエンドツール界隈の技術がカオスすぎて混乱している方」「モダンなWeb開発の全体像をとらえたい方」というのがまさに自分で、このコースでNode.jsを中心とした技術について大まかに学ぶことが出来たので良かったです。 バックエンドの部分に関しては特に時間を取って解説されていますが、他の部分については基礎や重要なところをピックアップしているという感じなので、個々の技術に関して詳細に知りたいという人にはあまり向かないかもしれません。大まかに学んで個々の技術の学習に繋げたいと思う人にはかなりオススメ出来るコースだと思います。

Charts

Price

Node.jsで学ぶWebシステムとソフトウェア開発基礎!Node.js完全入門ガイド - Price chart

Rating

Node.jsで学ぶWebシステムとソフトウェア開発基礎!Node.js完全入門ガイド - Ratings chart

Enrollment distribution

Node.jsで学ぶWebシステムとソフトウェア開発基礎!Node.js完全入門ガイド - Distribution chart

Related Topics

4909088
udemy ID
10/2/2022
course created date
11/26/2022
course indexed date
Bot
course submited by