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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

JavaScript

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

Q&A

解決済

1回答

1080閲覧

画像プレビュー機能で画像が表示されている場合のみ、すでに存在している画像を削除するところでプレビュー画像以外の画像を消してしまう問題点を解決したい

kengoal

総合スコア1

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

JavaScript

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

0グッド

0クリップ

投稿2021/01/20 15:16

前提・実現したいこと

rubyでjsファイルを使ってプレビュー機能を実装しています
現状プレビューはできているのですがプレビューしたときに
image_tagで貼り付けてある他の画像が消えてしまい
画像をプレビューで変えるたび更に他の画像が消えてしまうので
プレビュー画像は変えられるけど他の画像は消えないようにしたいです

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

エラーメッセージ

該当のソースコード

ruby

1ソースコード <header class='top-page-header'> 2 <div class='search-bar-contents'> 3 <%= link_to image_tag("cook-do1.png", class:"furima-icon", id:"cook-do1"), "/" %> 4 <form class="search-form" action="#"> 5 <input class='input-box' placeholder='キーワードから探す'> 6 <button class="search-button"> 7 <%= image_tag "search.png", class:"search-icon", id:"search-icon" %> 8 </button> 9 </form> 10 </div> 11 <div class='nav'> 12 <ul class='lists-left'> 13 <li><%= link_to 'ジャンル', "#", class: "category-list" %></li> 14 </ul> 15 <ul class='lists-right'> 16 <% if user_signed_in? %> 17 <li><%= link_to 'レシピ作成', new_user_recipe_path(:user_id), method: :get, class: "recipe_new" %></li> 18 <li><%= link_to current_user.nickname, "", class: "user-nickname" %></li> 19 <li><%= link_to 'ログアウト', destroy_user_session_path, method: :delete, class: "logout" %></li> 20 <% else %> 21 <li><%= link_to 'ログイン', new_user_session_path, method: :get, class: "login" %></li> 22 <li><%= link_to '新規登録', new_user_registration_path, method: :get, class: "sign-up" %></li> 23 <% end %> 24 </ul> 25 </div> 26</header> 27### 省略 ### 28<label class="#">料理の画像</label> 29 <%= f.file_field :image, id:"message_image"%> 30 <div id="image-list"></div>``` 31 32``````java 33 34```java 35document.addEventListener('DOMContentLoaded', function(){ 36 const ImageList = document.getElementById('image-list'); 37 38 const createImageHTML = (blob) => { 39 // 画像を表示するためのdiv要素を生成 40 const imageElement = document.createElement('div'); 41 42 // 表示する画像を生成 43 const blobImage = document.createElement('img'); 44 blobImage.setAttribute('src', blob); 45 46 47 48 // 生成したHTMLの要素をブラウザに表示させる 49 imageElement.appendChild(blobImage); 50 ImageList.appendChild(imageElement); 51 }; 52 53 document.getElementById('message_image').addEventListener('change', function(e){ 54 // 画像が表示されている場合のみ、すでに存在している画像を削除する 55 const imageContent = document.querySelector('img'); 56 if (imageContent){ 57 imageContent.remove(); 58 } 59 60 const file = e.target.files[0]; 61 const blob = window.URL.createObjectURL(file); 62 63 createImageHTML(blob); 64 65 66 }); 67 });
### 試したこと querySelectorでimgと漠然と取得しているからか だからimg全般から取得して消去するのでimage-tagのimgも対象になってしまう 限定的に値を検索することができるのか色々調べてみましたが たどり着けませんでした ### 補足情報(FW/ツールのバージョンなど) ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

createImageHTML するときに id を設定して削除時にそれを指定すれば良いのではないでしょうか。

js

1const createImageHTML = (blob) => { 2 ... 3 const imageElement = document.createElement('div'); 4 imageElement.id = "currentThumb" 5 ...

js

1document.getElementById('message_image').addEventListener('change', function(e){ 2 ... 3 const imageContent = document.querySelector('#currentThumb'); 4 ...

投稿2021/01/21 00:23

neko_daisuki

総合スコア2090

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

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

kengoal

2021/01/21 02:52

imageElementに紐付くidを設定して querySelectorでそのidを取得するのですね! 取得の仕方がわからなくて途方にくれていたところ 助かりました!ありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問