JavaScriptと比較したTypeScriptの使い方

image

この記事は、【 可茂IT塾 Advent Calendar 2022 】の21日目の記事です。

はじめに

Next.jsを学習しているうちにTypeScriptはJavaScriptと何が違うのか気になったので、調べたことを簡単にまとめてみました。
JavaScriptとの違いを踏まえながらTypeScriptの使い方について書いていきます。

JavaScriptとTypeScriptの違い

JavaScriptが動的型付けなのに対して、TypeScriptは静的型付けです。
動的型付けとは、コードに型を宣言しなくても自動的に型推論を行ってくれるものです。
静的型付けとは、コードに型を宣言する必要があり、型が無いとエラーになります。

例えばJavaScriptでは文字を定義したいとき、以下のように書きます。

let sample="サンプル";

TypeScriptの例を以下に示します。

let sample:string="サンプル";

TypeScriptの型

ここでは、いくつかの型を代表して紹介します。
上から、TypeScript、JavaScriptの例になります。

string

文字列の型です。
上と同じ例を載せます。

let sample="サンプル";
let sample:string="サンプル";

number

数値の型です。

let num=123;
let num:number=123;

boolean

trueかfalseをもつ型です。

let isDone=true;
let isDone:boolean=true;

Array

配列の型です。

let fruits=["apple","banana","orange"];
let fruits:string[]=["apple","banana","orange"];

Object

オブジェクトの型です。

let myDog={
    name:"leo",
    age:10,
    weight:5
}
interface dogData={
    name:string,
    age:number,
    weight:number
}

let myDog:dogData={
name:"leo",
age:10,
weight:5
}

TypeScriptの場合はオブジェクトの型を作るためにインターフェースが必要になります。
また、要素があるか分からない場合などはインターフェースを以下の様に書くことでエラーが起こらなくなります。

ageを例にとります。

interface dogData={
    name:string,
    age?:number,
    weight:number
}

また、ageは存在するがnullかもしれない場合には次のように書きます。

interface dogData={
    name:string,
    age:number|null,
    weight:number
}

関数の定義

function func(a,b){
return a+b;
}
function func(a:number,b:number):number{
return a+b;
}

number型a,bを引数にとってnumber型を返り値(a+b)にしています。

お知らせ

3月19日開催のアプリ開発講座の参加者募集中!!

3月19日開催のアプリ開発講座の参加者募集中!!

3月19日にアプリ開発講座を開催します!会場は岐阜県美濃加茂市のコワーキングスペース「こやぁね」です。興味のある方は是非ご参加ください!

Read More
可茂IT塾ではFlutterインターンを募集しています!

可茂IT塾ではFlutterインターンを募集しています!

可茂IT塾ではFlutterインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。

Read More

タグ

Flutter (70)初心者向け (22)イベント (15)Nextjs (8)Google Apps Script (7)可茂IT塾 (6)Firebase (6)React (5)新卒 (3)就活 (3)給与支払報告書 (3)riverpod (3)Dart (3)JavaScript (3)TypeScript (3)インターン (3)FlutterWeb (2)画像 (2)アプリ開発 (2)React Hooks (2)tailwindcss (2)ワーケーション (2)社会人 (2)大学生 (2)お知らせ (2)webfeed (1)RSS (1)CodeRunner (1)VSCode (1)個人開発 (1)設計 (1)フルリモート (1)学生向け (1)Java (1)Spring Boot (1)エンジニア (1)DeviceOrientation (1)正規表現 (1)神楽 (1)趣味紹介 (1)プログラミングだけではない可茂IT塾のメンバー (1)線型計画法 (1)事例 (1)PreferredSize (1)マテリアルデザイン (1)Material (1)クパチーノデザイン (1)Cupertino (1)ListView (1)就活浪人 (1)既卒 (1)保守性 (1)シェアハウス (1)スクレイピング (1)Gmail (1)Googleグループ (1)GoogleWorkspace (1)ShaderMask (1)google map (1)Google Places API (1)Vercel (1)Google Domains (1)branch (1)Git (1)オンラインオフィス (1)Freezed (1)アイコン (1)Apple Store Connect (1)FlutterGen (1)検索機能 (1)Navigator (1)メール送信 (1)カスタム認証 (1)アニメーション (1)FloatingActionButton (1)Arduino (1)ESP32 (1)経験談 (1)フリーランス (1)Dialog (1)Figma (1)デザイン (1)Slack (1)BI (1)非同期処理 (1)BackdropFilter (1)iOS (1)レビュー (1)getAuth (1)匿名 (1)Algolia (1)chakra-ui (1)コンサルティング (1)Symbol (1)reactive_forms (1)

お知らせ

3月19日開催のアプリ開発講座の参加者募集中!!

3月19日開催のアプリ開発講座の参加者募集中!!

3月19日にアプリ開発講座を開催します!会場は岐阜県美濃加茂市のコワーキングスペース「こやぁね」です。興味のある方は是非ご参加ください!

Read More
可茂IT塾ではFlutterインターンを募集しています!

可茂IT塾ではFlutterインターンを募集しています!

可茂IT塾ではFlutterインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。

Read More