data:image/s3,"s3://crabby-images/7dbaf/7dbaf660182fa7af2aad101edffdd696a52e388c" alt="見出し画像"
GAS(Google Apps Script)の始め方②(はじめてのwebアプリ作成編)
GAS(Google Apps Script)の始め方①(準備編)では、ログインするまでの方法を紹介しました。
第2回目では、Webアプリの簡単な作成方法について紹介します。
GAS(Google Apps Script)にログインすると、次のような画面になります。
data:image/s3,"s3://crabby-images/4104e/4104ef49c702201bbe67d0ece9b28f7314112515" alt=""
①新しいプロジェクトの作成
左側のメニューから、「新しいプロジェクト」をクリックします。
data:image/s3,"s3://crabby-images/e907b/e907b23369c39e874904cad6f04557b0099566e4" alt=""
無題のプロジェクトというページが開かれます。
コードエディタが現れるので、これからコードを変更していきます。
data:image/s3,"s3://crabby-images/cd28c/cd28c2a43383cec91fcde947e29755b58a31d2a1" alt=""
②コード.gsの内容を編集
まずは、コード.gsの内容を変更します。
次のように記述されているので、これを下のコードに変更します。(コピー&ペースト)
data:image/s3,"s3://crabby-images/5438b/5438b6e4a967ef2c2385301d5a4b4665ffe49972" alt=""
function doGet(e) {
const template = HtmlService.createTemplateFromFile('index');
const htmlOutput = template.evaluate();
return htmlOutput;
}
詳しい意味については、今回は触れないようにしたいと思いますが、
ユーザーが このWeb アプリケーションにアクセスした際に、指定された HTML ファイル(index.html)をブラウザに表示するようにしています。
③index.htmlの作成 及び 内容の変更
まず、index.htmlを作成します。
ファイルの右側にある「+」をクリックして、
HTMLを選びます。(クリック)
data:image/s3,"s3://crabby-images/64830/64830224e1dd1c5bd7170315fb5bfb2c03f97509" alt=""
ファイル名を「無題」から「index」に変更します。
data:image/s3,"s3://crabby-images/5576a/5576a9f96582c6b9315936139aee29180831fa81" alt=""
続いて、index.htmlの内容を編集します。
index.htmlの内容を変更して、index.htmlを開くと、「Hello world!!」と表示するようにします。
index.htmlについて、
<!DOCTYPE html>から</html>の内容を、
下のコードに変更します。(コピー&ペースト)
data:image/s3,"s3://crabby-images/437cd/437cd6ef8c1121678329addd2405543cbba71412" alt=""
<!DOCTYPE html>
<html>
<head>
<base target="_top">
</head>
<body>
<div id="text"></div>
<script>
document.getElementById("text").innerHTML = "Hello world!!";
</script>
</body>
</html>
具体的には、<body>と</body>の中に、
<div>要素を追加し、idをtextと指定しています。
その動きを<script>から</script>の中に、
Javascriptでプログラム(idがtextの要素に「Hello world!!」を追加)を記述しています。
④プロジェクト名を変更して、保存します。
プロジェクト名(赤い四角で囲まれた部分)を変更します。(なんでもかまいません。ここでは、仮に『はじめてのGASプログラム』としました。)
続いて、プロジェクトを保存します。
フロッピーディスク(赤い四角で囲まれた部分)のアイコンをクリックします。
data:image/s3,"s3://crabby-images/1251e/1251e88ef86cbd030561399344f15d3198914d5b" alt=""
⑤webアプリの作成(webアプリとしてデプロイを行う)
画面右上にデプロイと書かれた青いボタンがあるので、クリックします。
data:image/s3,"s3://crabby-images/c19f4/c19f4d59911542f0de1588372dbc07f00cb47e97" alt=""
新しいデプロイを選択します。
data:image/s3,"s3://crabby-images/c5f77/c5f77426c03ad0eaaf06c35cc2352f041b65f831" alt=""
デプロイタイプを選択します。
左上の歯車のアイコンをクリックし、ウェブアプリを選択します。
data:image/s3,"s3://crabby-images/3caa4/3caa434adb89cedf36b4dc4651cb6efd83e13d2e" alt=""
ウェブアプリの設定を行います。
今回は、ウェブアプリとして動くかどうか確かめるだけなので、
そのままの設定で、右下の「デプロイ」をクリック。
data:image/s3,"s3://crabby-images/0d9d7/0d9d73a28c737b7bee109bf4c2c5fcc7290bf4c5" alt=""
そうすると、「デプロイを更新しました。」と表示されるので、ウェブアプリの下のURL(https://script.google.com/~以下省略~)をクリックします。
data:image/s3,"s3://crabby-images/9d734/9d7346ffd55886e9e3f0ef63d8216c23117ffe3d" alt=""
ウェブページが開き、無事「Hello world!!」と表示されています。
data:image/s3,"s3://crabby-images/9e7a6/9e7a64f1bd037a2707f694cb83362404c2c193a5" alt=""
Webアプリの完成!
お疲れさまでした。これで、はじめてのwebアプリの完成です。
index.htmlの内容を変更すれば様々なwebアプリを作ることができます。
今回はここまでです。
続きは、
もう少しwebアプリを作りたい場合は、以下に発展編を記載しておきます。良かったら、参考にしてして下さい。
※発展として
index.htmlの内容を変更して、簡単なタイマーアプリを作ってみたいと思います。
index.htmlの内容を次のコードに変更します。(コピー&ペースト)
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>シンプルなタイマー</title>
<style>
body {
font-family: Arial, sans-serif;
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
background-color: #f0f0f0;
}
.timer-container {
text-align: center;
background: #fff;
padding: 20px;
border-radius: 8px;
box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}
#timer-display {
font-size: 100px;
}
input {
width: 40px;
padding: 3px 0px;
margin-right: 5px;
text-align: center;
}
button {
padding: 3px 30px;
margin-top: 5px;
font-size: 16px;
}
</style>
</head>
<body>
<div class="timer-container">
<div id="timer-display">00:00</div>
<div>
<input type="number" id="minutes" placeholder="min" min="0" value="3">:
<input type="number" id="seconds" placeholder="sec" min="0" max="59" value="00">
</div>
<button id="start-button">start</button>
<button id="pause-button" disabled>pause</button>
<button id="reset-button" disabled>reset</button>
</div>
<script>
document.addEventListener('DOMContentLoaded', function() {
const minutesInput = document.getElementById('minutes');
const secondsInput = document.getElementById('seconds');
const startButton = document.getElementById('start-button');
const pauseButton = document.getElementById('pause-button');
const resetButton = document.getElementById('reset-button');
const timerDisplay = document.getElementById('timer-display');
let countdown;
let timeLeft;
let isPaused = false;
startButton.addEventListener('click', function() {
const minutes = parseInt(minutesInput.value) || 0;
const seconds = parseInt(secondsInput.value) || 0;
timeLeft = (minutes * 60) + seconds;
if (timeLeft > 0) {
startButton.disabled = true;
pauseButton.disabled = false;
resetButton.disabled = false;
startCountdown();
}
});
pauseButton.addEventListener('click', function() {
if (isPaused) {
startCountdown();
pauseButton.textContent = 'pause';
isPaused = false;
} else {
clearInterval(countdown);
pauseButton.textContent = 'resume';
isPaused = true;
}
});
resetButton.addEventListener('click', function() {
clearInterval(countdown);
timerDisplay.textContent = '00:00';
startButton.disabled = false;
pauseButton.disabled = true;
resetButton.disabled = true;
minutesInput.value = '3';
secondsInput.value = '00';
pauseButton.textContent = 'pause';
isPaused = false;
});
function startCountdown() {
countdown = setInterval(function() {
if (timeLeft <= 0) {
clearInterval(countdown);
timerDisplay.textContent = '00:00';
alert('時間です!');
startButton.disabled = false;
pauseButton.disabled = true;
resetButton.disabled = true;
} else {
timeLeft--;
updateDisplay();
}
}, 1000);
}
function updateDisplay() {
const minutes = Math.floor(timeLeft / 60);
const seconds = timeLeft % 60;
timerDisplay.textContent =
`${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;
}
});
</script>
</body>
</html>
次に、変更したプロジェクトを保存します。
フロッピーディスクのアイコンをクリック。
data:image/s3,"s3://crabby-images/5333c/5333cf26b97765741e6d742567b828330468800a" alt=""
右上の「デプロイ」から「デプロイの管理」をクリック
data:image/s3,"s3://crabby-images/afc13/afc1366e9f4a8bd2d029515cb98b4b217c911721" alt=""
バージョンは、「新バージョン」に
説明は、何でも良いのですが、一応ここでは「タイマー」としました。
data:image/s3,"s3://crabby-images/4225d/4225d23c2ada249a77ecf701abbabe52e01626b3" alt=""
次のユーザーとして実行は、自分だけが使用する想定だとして「自分」を選択。
※他の人も使用する想定なら「ウェブアプリケーションにアクセスしているユーザー」を選択します。
※他の人が使用する場合でも、実行するユーザーを自分にしておきたい場合もあります。
data:image/s3,"s3://crabby-images/f4b8d/f4b8d7c45f88f8529dabfd9a90fd981d01424ce1" alt=""
アクセスできるユーザーは、ここでは「自分のみ」を選択。
※ここでも、他のユーザーが使用するかどうかで選択する項目が変わります。
data:image/s3,"s3://crabby-images/72ecd/72ecd14a14964bdd8dab20de23e17effaa24053a" alt=""
設定後、右下の「デプロイ」をクリックすると、
「デプロイが更新されました」と表示され、
バージョンが2となります。
data:image/s3,"s3://crabby-images/d4ae3/d4ae37e6d68fe1aac7cd85e568fd2d7df958cf8d" alt=""
ウェブアプリのURLをクリックすると、
修正したwebアプリが表示されます。
data:image/s3,"s3://crabby-images/ac71d/ac71d92bf0caca0dbbb05d3aa7baf551720488bf" alt=""
タイマーアプリが完成しました。