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

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

新規登録して質問してみよう
ただいま回答率
87.20%
Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

HTTP

HTTP(Hypertext Transfer Protocol)とはweb上でHTML等のコンテンツを交換するために使われるアプリケーション層の通信プロトコルです。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

受付中

Goでメソッドの処理状況をブラウザに返すプログレスバーは導入できるのか?

mimi_129
mimi_129

総合スコア63

Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

HTTP

HTTP(Hypertext Transfer Protocol)とはweb上でHTML等のコンテンツを交換するために使われるアプリケーション層の通信プロトコルです。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

2回答

0評価

0クリップ

741閲覧

投稿2022/05/21 07:39

編集2022/06/11 17:22

実現したいこと

ブラウザで使用するアプリケーションを作っています。
その中で、あるGoのメソッドで記述が多く完了まで時間が掛かるメソッドがあります。
発火はReactからのpostです。
進行状況の確認をブラウザで行いたいと思っているのですが、
そもそもそのような事は可能なのでしょうか?

コンソール上でプログレスバーを入れるライブラリは見つけましたが、
httpで行う事は難しいでしょうか?

1度のリクエストで断続的にクライアントにレスポンスを返し続けるのは可能なのでしょうか?

開発環境は、
フロントがReact、
バックエンドがGoです。

色々と初歩的な質問ですいません。

<<追記>>

App.js

import React from 'react'; import axios from 'axios'; import imgLogo from './images/logo.png'; import './css/style.css' class App extends React.Component { constructor() { super(); this.state = { } } interval = async() => { console.log("interval start") let res = await fetch("/api/progress"); let data = await res.json(); let progress = document.getElementById("progress"); progress.value = data.progress; progress.innerHTML = data.progress + "%"; } start = async() => { console.log("start start") let progress = document.getElementById("progress"); progress.value = 0; progress.innerHTML = "0%"; let id = setInterval(this.interval(), 1000); await fetch("/api/longtask"); clearInterval(id); window.alert("long task completed"); } render() { return ( <div> <div className="container"> <button id="start" onClick={async () => {await this.start();} }>start</button> <progress id="progress" max="100" value="0">0%</progress> </div> </div> ) } } export default App;

handler.go

package handler import ( // "encoding/json" "fmt" "net/http" "sync" "time" _ "github.com/jinzhu/gorm/dialects/postgres" _ "github.com/lib/pq" "github.com/labstack/echo/v4" "github.com/labstack/echo/v4/middleware" ) type Progress struct { sync.RWMutex Progress int `json:"progress"` } func Handler() { e := echo.New() e.Use(middleware.CORS()) // ルーティング e.GET("/progress", progress) e.GET("/longtask", longtask) // local サーバー e.Logger.Fatal(e.Start(":8000")) return } func progress(c echo.Context) (err error) { progress := &Progress{} fmt.Printf("progress start") progress.RLock() c.JSON(http.StatusOK, progress) progress.RUnlock() return } func longtask(c echo.Context) error { progress := &Progress{} for i := 0; i <= 10; i++ { progress.Lock() progress.Progress = i * 10 progress.Unlock() time.Sleep(time.Second) } return nil }

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

mimi_129

2022/05/28 07:49

ありがとうございます。 参考にさせていただきます。

まだ回答がついていません

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

HTTP

HTTP(Hypertext Transfer Protocol)とはweb上でHTML等のコンテンツを交換するために使われるアプリケーション層の通信プロトコルです。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。