質問するログイン新規登録

Q&A

1回答

86閲覧

【スプレッドシート GAS + ウェブアプリ】スクリプトレット記法で宣言した変数の値を変えたい

logix

総合スコア0

Google Apps Script

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

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

0グッド

0クリップ

投稿2025/12/05 03:55

0

0

実現したいこと

スプレッドシート+Google Apps Script(GAS)で社内報を開発しております。
フロントのhtml内で、ボタンを押してスクリプトレット記法<? 〜 ?>内の変数の値を変更したいのですが、上手く動作しないため、ご存じでしたら教示いただけますと大変助かります。

発生している問題・分からないこと

ボタンを押すたびにスクリプトレット記法内の変数に対してカウントアップができる方法を探しています。
動作としてはソースのfnc003が成功になります。

該当のソースコード

Javascript

1 2<input type="button" onclick="fnc001()" value="ボタン1"><!-- 実行結果:1がずっと続く --> 3<input type="button" onclick="fnc002()" value="ボタン2"><!-- 実行結果:2がずっと続く --> 4<input type="button" onclick="fnc003()" value="ボタン3"><!-- 実行結果:成功(1,2,3,4,5... --> 5<? 6 output._ = '<input type="button" onclick="fnc002()" value="ボタン4">'; //実行結果:2がずっと続く 7?> 8 9<script> 10<? 11 let val = 0; 12 13 function countup(){ 14 val++; 15 return val; 16 } 17?> 18 19function fnc001(){ 20 <? val++; ?> 21 alert(<?= val ?>); 22} 23 24function fnc002(){ 25 alert(<?!= countup(); ?>); 26} 27 28let num =0; 29function fnc003(){ 30 num++; 31 alert(num); 32} 33</script>

試したこと・調べたこと

  • teratailやGoogle等で検索した
  • ソースコードを自分なりに変更した
  • 知人に聞いた
  • その他
上記の詳細・結果

google.script.runを使用してコード.gs内の関数を呼び出す方法で一応は実現できたのですが、動作速度に難がありました。
スクリプトプロパティを設定するなどもあると思うのですが、可能であれば.htmlファイル内で解決させたいです。

補足

コード.gs内からgoogleスプレッドシートをgetValuesした配列をフロント側で操作している際に必要となった問題ですが、質問はシンプルにさせていただきました。

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

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

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

guest

回答1

0

 スクリプトレット記法での変数や関数はサーバ側に保持されているため、クライアント側では動作しないというのが私の理解です。スクリプトレット記法での変数や関数はレンダリング時に評価され、HTMLの中の文字列になっていると思います。

ただし、テンプレート コードはページがユーザーに配信される前に実行されるため、これらの手法でページに渡せるのは初期コンテンツのみです。ページから Apps Script データにインタラクティブにアクセスするには、代わりに google.script.run API を使用します。
HTML サービス: テンプレート化された HTML  |  Apps Script  |  Google for Developers

 変更できる旨の記述をどこかでご覧になっているようでしたら、そのURLなどをご提示いただいた方が話が早いかもしれません。

投稿2025/12/05 08:35

Lhankor_Mhy

総合スコア37671

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.29%

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

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

質問する

関連した質問