前提・実現したいこと
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/ツールのバージョンなど) ここにより詳細な情報を記載してください。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/01/21 02:52