質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google サイト

Google サイトは、Google社が提供する無料のホームページ作成ツールです。プログラミングやデザインなどの知識がなくても、ブラウザから容易にWebページを作成することが可能。新たなページの追加も簡単でページ数には制限がありません。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

1回答

5051閲覧

GASのHTMLの中でFor文を回してリストとして表示したい

FrustratedByBug

総合スコア7

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google サイト

Google サイトは、Google社が提供する無料のホームページ作成ツールです。プログラミングやデザインなどの知識がなくても、ブラウザから容易にWebページを作成することが可能。新たなページの追加も簡単でページ数には制限がありません。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2020/12/22 07:29

編集2020/12/22 07:44

前提・実現したいこと

Google Apps Script(GAS)で動的なウェブページを作ることを試みています。
その機能は端的に言えば、スプレッドシートのデータを見やすく整形して表示するというものです。

この際、以下のウェブサイトを参考にほぼ同じようなコードを書いてみましたが、うまくいきません。

このサイトです(https://tonari-it.com/gas-web-appli-spreadsheet-append)

発生している問題・エラーメッセージ

TypeError: output.append is not a function

以上のエラーコードが出てしまいます。

該当のソースコード

HTMLファイルのソースコードはこちらです。
ファイル名は"stu_info.html"となっています。

html

1<!DOCTYPE html> 2<html lang="ja"> 3 4<head> 5 <meta charset="UTF-8"> 6 <meta name="viewport" content="width=device-width, initial-scale=1.0"> 7 <meta http-equiv="X-UA-Compatible" content="ie=edge"> 8 <title>Home Page</title> 9 <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous"> 10 <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script> 11 <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script> 12 <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script> 13</head> 14 15<body> 16 17 <div class="contents-wrapper"> 18 19 <div class="main-wrapper"> 20 <ul> 21 22  <? 23  var ssDataTable = SpreadsheetApp.openById("???").getSheetByName("DataTable"); 24 25  var gradeList = ssDataTable.getRange(1,1,13,1).getValues(); 26 27  Logger.log(gradeList) 28 29  for(var i=0; i<gradeList.length; i++){ 30   Logger.log("gradeList[%s][0]:%s",i,gradeList[i][0]); 31   output.append("<li>" + gradeList[i][0] + "</li>"); 32  } 33 34  Logger.log(output.getContent()); 35 36  ?> 37 38 </ul> 39 </div> 40 </div> 41 42</body> 43 44</html> 45 46

GASのDoGet関数は以下です。

GAS

1const doGet = (e) => { 2 const page = (e.parameter.p || "stu_info"); 3 4 return htmlOutput = HtmlService.createTemplateFromFile(page) 5 .evaluate() 6 .setTitle("Home Page") 7 .addMetaTag('viewport', 'width=device-width,initial-scale=1'); 8};

試したこと

エラーコードにoutput.apppendが関数でないとあったため、ためしにHtmlOutputクラスとしてOutputを定義しました。

公式のドキュメンテーションを参照したところ、output.appendはHtmlOutputクラスの関数であったため、

html

1for(var i=0; i<gradeList.length; i++){ 2   Logger.log("gradeList[%s][0]:%s",i,gradeList[i][0]); 3   output.append("<li>" + gradeList[i][0] + "</li>"); 4  }

これを以下のように初めにcreateHtmlOutput()しました。

var output = HtmlService.createHtmlOutput(""); for(var i=0; i<gradeList.length; i++){    Logger.log("gradeList[%s][0]:%s",i,gradeList[i][0]);    output.append("<li>" + gradeList[i][0] + "</li>");   }

しかし、問題は解決されず、eval()の中で同じエラーが出現しました。

###試したこと2

返り値を返す必要があるかと思い、Return文を書きましたが、関係なさそうでした。

HTML

1 2<? 3  var ssDataTable = SpreadsheetApp.openById("???").getSheetByName("DataTable"); 4 5  var gradeList = ssDataTable.getRange(1,1,13,1).getValues(); 6 7  Logger.log(gradeList) 8 9  for(var i=0; i<gradeList.length; i++){ 10   Logger.log("gradeList[%s][0]:%s",i,gradeList[i][0]); 11   output.append("<li>" + gradeList[i][0] + "</li>"); 12  } 13 14  Logger.log(output.getContent()); 15  return output 16  ?>

補足情報(FW/ツールのバージョンなど)

Versionは現行です。

大変困っておりますので、もしよろしければ、お分かりの方、よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

GAS

1const myfunction = () =>{ 2  var ssDataTable = SpreadsheetApp.openById("???").getSheetByName("DataTable"); 3 4  var gradeList = ssDataTable.getRange(1,1,13,1).getValues(); 5 6  Logger.log(gradeList) 7 8  for(var i=0; i<gradeList.length; i++){ 9   Logger.log("gradeList[%s][0]:%s",i,gradeList[i][0]); 10   output.append("<li>" + gradeList[i][0] + "</li>"); 11  } 12 13  Logger.log(output.getContent()); 14  return output 15 }

と処理を関数にして、スクリプトレットを

html

1<?!=myfunction().getContent()?>

としたらうまくゆきました。

投稿2020/12/22 08:48

FrustratedByBug

総合スコア7

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問