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

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

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

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

Ruby on Rails

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

JavaScript

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

Q&A

解決済

1回答

1216閲覧

編集画面にて、カテゴリーを変更したら親子孫がリセットされる様にしたい

keisuke.F

総合スコア19

Ruby

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

Ruby on Rails

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

JavaScript

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

0グッド

0クリップ

投稿2020/09/17 12:45

編集2020/09/17 13:45

お世話になっております。
現在、プログラミングスクールにて、チーム開発でフリマアプリを開発しています。
現在、出品した商品を編集する機能を実装しています。

解決したいこと

カテゴリの変更で、既存のカテゴリを削除したい。

#仮説
カテゴリーが変更された時にenptyメソッド等で既存のカテゴリーを空にすればよいのでは?と仮説を立てた。

edit.html.haml

.sell-new .sell-new__wrapper .sell-new__wrapper__form = form_for @item do |f| %ul - @item.errors.full_messages.each do |message| %li= message .sell-new__wrapper__form__field.append__category = f.label :"カテゴリー" %span.sell-new__wrapper__form__field__attention 必須 %br/ =f.collection_select :category_id, @item.category.root.siblings, :id, :name, class:"serect_field" =f.collection_select :category_id, @item.category.parent.siblings, :id, :name, class:"serect_field" =f.collection_select :category_id, @item.category.siblings, :id, :name, class:"serect_field" //省略

items_edit.js
こちらは、出品機能のjsをコピーしたものです。

$(document).on('turbolinks:load', ()=> { function appendOption(category){ var html = `<option value="${category.id}">${category.name}</option>`; return html; } function appendChildrenBox(insertHTML){ var childSelectHtml = ""; childSelectHtml = `<div class="category__child" id="children_wrapper"> <select id="child__category" name="item[category_id]" class="serect_field"> <option value="">---</option> ${insertHTML} </select> </div>`; $('.append__category').append(childSelectHtml); } function appendGrandchildrenBox(insertHTML){ var grandchildSelectHtml = ""; grandchildSelectHtml = `<div class="category__child" id="grandchildren_wrapper"> <select id="grandchild__category" name="item[category_id]" class="serect_field"> <option value="">---</option> ${insertHTML} </select> </div>`; $('.append__category').append(grandchildSelectHtml); } $('#item_category_id').on('change',function(){ var parentId = document.getElementById('item_category_id').value; if (parentId != ""){ $.ajax({ url: '/items/get_category_children/', type: 'GET', data: { parent_id: parentId }, dataType: 'json' }) .done(function(children){ $('#children_wrapper').remove(); $('#grandchildren_wrapper').remove(); var insertHTML = ''; children.forEach(function(child){ insertHTML += appendOption(child); }); appendChildrenBox(insertHTML); }) .fail(function(){ alert('カテゴリー取得に失敗しました'); }) }else{ $('#children_wrapper').remove(); $('#grandchildren_wrapper').remove(); } }); $('.append__category').on('change','#child__category',function(){ var childId = document.getElementById('child__category').value; if(childId != "" && childId != 46 && childId != 74 && childId != 134 && childId != 142 && childId != 147 && childId != 150 && childId != 158){ $.ajax({ url: '/items/get_category_grandchildren', type: 'GET', data: { child_id: childId }, dataType: 'json' }) .done(function(grandchildren){ $('#grandchildren_wrapper').remove(); var insertHTML = ''; grandchildren.forEach(function(grandchild){ insertHTML += appendOption(grandchild); }); appendGrandchildrenBox(insertHTML); }) .fail(function(){ alert('カテゴリー取得に失敗しました'); }) }else{ $('#grandchildren_wrapper').remove(); } }) });

現状、既存の親子孫のカテゴリーを残したまま4つめのセレクトボックスが出現してしまいます。

ご教授ください。
よろしくお願い致します。

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

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

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

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

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

guest

回答1

0

自己解決

子孫カテゴリーにremoveメソッドの記述に記載していたidを付与してあげて解決しました!

投稿2020/09/18 02:59

keisuke.F

総合スコア19

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問