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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

ドラッグ&ドロップ

コンピューターのGUIにおいて、バーチャルなものを「つかむ」ことによって選択し、別の場所や他のバーチャルなものの上に動かす行為、またはその行為に対応していることを指す。

JavaScript

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

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

Q&A

0回答

461閲覧

ドラッグ&ドロップした後のデータのみをDBに保存したい

hakushin_man

総合スコア3

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

ドラッグ&ドロップ

コンピューターのGUIにおいて、バーチャルなものを「つかむ」ことによって選択し、別の場所や他のバーチャルなものの上に動かす行為、またはその行為に対応していることを指す。

JavaScript

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

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

0グッド

0クリップ

投稿2021/02/15 10:33

前提・実現したいこと

アルバイトのシフト作成のアプリを作っています。
DBに保存されたデータをjsを使い繰り返し処理されているdiv要素をshift_tableのtdの中にドラッグ&ドロップができるようにしました。

その上でドロップした要素はdiv要素なのでこの中にある文字列をDBに保存したい。

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

ドロップした後にそのコードを見てみると

html

1<td id="shift_num1" ondragover="onDragOver(event);" ondrop="onDrop(event);"> 2 <div id="human1" class="employee_name" draggable="true" ondragstart="onDragStart(event);"> 3 田中 ひろし 4 </div> 5</td>

このようになっており、divの中に保存したい値が入ってしまいます。

該当のソースコード

Ruby,

1<div class="shift_main"> 2 <%= params[:date_save] %> 3 <div class="shift_set"> 4 <%= form_with(model: @form, url: root_path, local: true) do |form| %> 5 <table class="shift_table"> 6 <tbody class="shift_table_body"> 7 <tr class="shift_line"> 8 <td id="shift_num1" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 9 <td id="shift_num2" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 10 </tr> 11 <tr class="shift_line"> 12 <td id="shift_num3" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 13 <td id="shift_num4" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 14 </tr> 15 <tr class="shift_line"> 16 <td id="shift_num5" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 17 <td id="shift_num6" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 18 </tr> 19 <tr class="shift_line"> 20 <td id="shift_num7" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 21 <td id="shift_num8" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 22 </tr> 23 <tr class="shift_line"> 24 <td id="shift_num9" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 25 <td id="shift_num10" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 26 </tr> 27 <tr class="shift_line"> 28 <td id="shift_num11" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 29 <td id="shift_num12" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 30 </tr> 31 <tr class="shift_line"> 32 <td id="shift_num13" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 33 <td id="shift_num14" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 34 </tr> 35 <tr class="shift_line"> 36 <td id="shift_num15" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 37 <td id="shift_num16" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 38 </tr> 39 <tr class="shift_line"> 40 <td id="shift_num17" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 41 <td id="shift_num18" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 42 </tr> 43 <tr class="shift_line"> 44 <td id="shift_num19" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 45 <td id="shift_num20" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 46 </tr> 47 </tbody> 48 </table> 49 <% end %> 50 <table> 51 <tbody> 52 <% @num.each do |day| %> 53 <tr> 54 <td class="employee"> 55 <div id="human1" class="employee_name" draggable="true" ondragstart="onDragStart(event);"> 56 <%= day.name %> 57 </div> 58 </td> 59 </tr> 60 <% end %> 61 </tbody> 62 </table> 63 </div> 64</div> 65<script type="text/javascript"> 66function onDragStart(event) 67{ 68 const nodes = Array.from(document.querySelectorAll(".employee_name")); 69 const index = nodes.findIndex(v=>v===event.target); 70 event.dataTransfer.setData('text/plain', index); 71} 72 73 74function onDragOver(event) { 75 event.preventDefault(); 76} 77 78function onDrop(event) 79{ 80 event.preventDefault(); 81 const index = event.dataTransfer.getData('text'); 82 const draggableElement = document.querySelectorAll(".employee_name")[index]; 83 const dropzone = event.currentTarget; 84 dropzone.appendChild(draggableElement); 85} 86</script> 87

試したこと

現状form_withを使っての保存を考えています。

form_with及びfields_forを使って保存するためのコード
f.hidden_field
に対してidを付与してその中にjsを使って入れ込むことができないかと試しましたがうまくいきませんでした。

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

Rubyのバージョンは6.0.0です。

また、コントローラーの記載が今回必要かどうかの判断ができなかったので、こちらに記載させていただきます。

ruby

1class ShiftController < ApplicationController 2 def index 3 end 4 5 def new 6 @shift = Shift.new 7 end 8 9 def create 10 @user_days = Day.where(shift_date: params[:date_save], ok_id: 2) 11 @num = [] 12 @user_days.each do |name| 13 @num << User.find(name.user_id) 14 end 15 end 16 17 def edit 18 end 19 20 private 21 def shift_params 22 params.require(:shift).merge(user_id: params[:user_id], ok_id: params[:ok_id], shift_date: params[:shift_date]) 23 end 24end 25

初学者にて質問に至らない点もあるかと思いますが、追記などはすぐに対応できるようにしますので、お答えいただけると幸いです。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問