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

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

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

FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

JavaScript

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

HTML

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

Q&A

解決済

2回答

2044閲覧

jsのsetAttributeでのsrcの変換がうまくいかない

to-kaido53

総合スコア1

Flask

FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

JavaScript

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

HTML

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

0グッド

0クリップ

投稿2021/08/09 18:25

pythonのflaskとjavascriptを使い開発している。
staticフォルダ内にpict_play.pngとpict_stop.png、該当のjsファイルを保存しており、同じフォルダ内でsetAttribute('src','pict_play.png')でsrcの書き換えを行ったが表示されない。

該当のソースコード

html

1<img src="{{url_for('static',filename='pict_stop.png')}}" alt="再生状態を表す画像" >

javascript

1var img=document.querySelector('img'); 2img.setAttribute('src','pict_play.png');

試したこと

setAttribute内のpict_play.pngをhtmlと同じように"url_for{{'static','pict_play.png')}}"と書き換えても表示されず。

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

pythonはanacondaのspyderを使い、js,htmlはvscで書いている。

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

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

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

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

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

guest

回答2

0

ベストアンサー

PythonもFlaskも分からないのでJavaScript観点だけで答えますが、画像のパスが違うだけでは?

setAttributeでsrcを書き換えるのはともかく、提示のコードsetAttribute('src','pict_play.png')だと<img src="pict_play.png">となります。
現在のURLからの相対パスで辿れるのでしょうか。

setAttribute内のpict_play.pngをhtmlと同じように

これは.js内で行っている場合、フレームワークもしくはテンプレートの処理が行われないからだと思います。
.jsを同じくテンプレート化できれば良いですが、ひとまず、同じHTMLテンプレート内に<script>タグとしてJavaScriptのコードを書けば良さそうにも思います(そこはフレームワークなりテンプレートエンジンの仕様に沿ってください)

もしくは「とりあえず」で<img src="{{url_for('static',filename='pict_stop.png')}}" alt="再生状態を表す画像" >この結果をブラウザ開発ツールからHTMLソース確認してpict_stop.pngの前の部分を得てsetAttributeの第2引数に直書きするとか。

画像URIをhiddenに埋め込んでそこから取得して結合するというやり方も考えられます。

html

1 2<input type="hidden" id="play_uri" value="{{url_for('static',filename='pict_play.png')}}">

js

1 2var play_uri=document.querySelector('#play_uri'); 3var img=document.querySelector('img'); 4img.setAttribute('src',play_uri);

※画像複数扱いたいならその数だけhiddenで用意するか、hiddenでstaticのuriだけ埋め込んでファイル名だけ結合するとか、やれなくはなさそうです。

投稿2021/08/09 20:17

編集2021/08/09 20:17
m.ts10806

総合スコア80875

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

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

to-kaido53

2021/08/11 10:58

ファイルパスは合っていたのですが、safariを使っていたため、何か不具合が発生したようでした。 Chromeで試して見た所解決いたしました。 回答ありがとうございました。 実際に記載いただいた内容でも問題なく表示されたため、ベストアンサーにさせていただきます。
m.ts10806

2021/08/11 23:36

Safariだから ではないと思います。 どういうサービスを想定されているか分かりませんが、Safariユーザーは一定はいるはずで、そのユーザーに対して想定の挙動を提供できないままなのはまずいのでは。
to-kaido53

2021/08/13 14:00

調べたところ、safariでjsがうまく動かないというのは実際あるようなので、それのせいにして勝手に自己完結してました… 本日改めてsafariで実行したところ、問題なく作動したので原因を探ってみます。 ありがとうございました。
guest

0

safariではなくChromeで試して見たところ、問題なく表示されました。

投稿2021/08/11 10:59

to-kaido53

総合スコア1

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問