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

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

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

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

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

Q&A

解決済

1回答

956閲覧

JSループにおける配列とオブジェクトについて

revoiot

総合スコア188

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

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

0グッド

0クリップ

投稿2021/08/26 13:35

前提・実現したいこと 試したこと

現在laravelで掲示板アプリを作成しているlaravel初心者です。
PHPのfoeachループで回して表示されている掲示板の全ての投稿のコメント入力画面に、vanillaJSの絵文字機能を実装したいと考えております。

絵文字機能自体は表示させることには成功し、選択した絵文字の要素をgetElementsByIdで取得した場合は、コメント入力画面にも選択した絵文字を挿入させることができたのですが、
JSのループの中でgetElementsByClassNameで要素取得させたところ、すべての投稿のコメント入力画面で絵文字を選択しても、コメント入力フォームに挿入されないで困っています。

配列とオブジェクトの理解が足りておらず、この現象になっているかもしれませんが、その部分なども含めてアドバイス等いただけると幸いです。

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

index.blade.php

php

1 2<input id="body" name="body" class="{form-control{{ $errors->has('body') ? 'is-invalid' : '' }}} emoji w-full focus:outline-none focus:placeholder-gray-400 text-gray-600 placeholder-gray-600 pl-12 bg-gray-200 rounded-full py-3 " value="{{ old('body') }}" type="text" placeholder="コメントを入力"> 3//input 4 5<button type="button" class="emoji-trigger inline-flex items-center justify-center rounded-full h-10 w-10 transition duration-500 ease-in-out text-gray-500 hover:bg-gray-300 focus:outline-none"></button> 6//

app.js

js

1//① node_modulesのモジュールをインポート 2import { EmojiButton } from '@joeattardi/emoji-button'; 3 4//② 要素取得など 5const picker = new EmojiButton();  6var trigger = document.getElementsByClassName("emoji-trigger");  7 8//③ 絵文字ボタンをクリックした後、絵文字選択画面を表示 9for(let i = 0; i < trigger.length; i ++){          10 trigger[i].addEventListener('click',function(){ 11 picker.togglePicker(trigger[i]); 12 }) 13} 14 15//④ 絵文字選択画面で選択した絵文字をコメント入力画面に挿入(エラー箇所) 16const picker2 = [] // ②で要素取得したpickerをオブジェクトから配列に変換して処理 17for(var k = 0; k<10; k++){ 18 const p = new EmojiButton(); 19 picker2.push(p) 20} 21for(let i = 0; i < picker2.length; i ++){ 22 picker2[i].on('emoji',function(selection){ 23 var selectedemoji = selection.emoji; 24 document.getElementsByClassName('emoji').value += selectedemoji;}) // 選択した絵文字をコメント入力画面に挿入 25 26

絵文字ピッカーのイメージ画像
動作イメージ
コメント入力欄にある絵文字ボタンをクリック
→絵文字選択画面(ピッカー)が開く。
→選択画面から入力したい絵文字を選択する
→コメント入力画面に挿入される。

![イメージ説明

絵文字選択後に、devtoolのコンソール画面の内容
![イメージ説明

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

Laravel Framework 7.30.2

MySQL 8.0.21 Homebrew

PHP 7.4.14

Docker 19.03.13

Heroku 7.47.2

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

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

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

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

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

mather

2021/08/26 13:40

app.js のファイルはそのままの状態で貼り付けていますか?全角空白が大量に含まれているようですが…
maisumakun

2021/08/26 13:45

書いてメリットがあるわけでもないですが、いちおうJavaScriptは「ソースコード中の全角スペースも単なるスペースとして処理される」言語です。
revoiot

2021/08/26 13:48 編集

matherさん ご指摘ありがとうございます。 いえ、コメントアウト部分(全角部分)は後で、質問用に付け足しています。 質問用に書き変えた箇所があるため、全角空白が含まれている可能性がございます。
revoiot

2021/08/26 13:47

maisumakunさん 全角部分があっても処理されるのですね。 教えていただきありがとうございます。
mather

2021/08/26 13:54

> JavaScriptは「ソースコード中の全角スペースも単なるスペースとして処理される」言語です それはそうなんですけど > コメントアウト部分(全角部分)は後で、質問用に付け足しています。 > 質問用に書き変えた箇所があるため、全角空白が含まれている可能性がございます。 こっちの方を心配していました。
revoiot

2021/08/26 13:58 編集

matherさん 御心配いただきありがとうございます。 私の言い方に語弊があり、すみません、、、 元ファイルのapp.jsにはコメントアウトを追記していないため大丈夫そうです。
guest

回答1

0

ベストアンサー

document.getElementsByClassNameは、Elementsと名前が複数形になっているように、複数取れることが前提となっていて、返り値は要素1つではなくコレクションです。

クラスでヒットする<input>が複数あるとすれば、どの要素へ絵文字を追加するのかを、何らかの方法で探し出さないといけません。

投稿2021/08/26 13:41

maisumakun

総合スコア145208

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

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

revoiot

2021/08/26 13:52

回答ありがとうございます。 取得する要素が複数あるため、コレクションを配列に格納しようと考えたのですが、どうもうまくいかないようです。 ④でどの部分の書き方に問題があるのでしょうか?
maisumakun

2021/08/26 13:55 編集

トリガーするボタンと、ボタンを押した後に絵文字を入力するフォームは、どのように紐付けてありますか? > ④でどの部分の書き方に問題があるのでしょうか? 「ここが悪い」というものではなく、そもそも考え方からしっかり立てないといけないところです。
revoiot

2021/08/26 14:16

質問の仕方が悪く、申し訳ございません。。。。 紐づけている部分は下記となります。 document.getElementsByClassName('emoji').value += selectedemoji;}) // 選択した絵文字をコメント入力画面に挿入 >取得する要素が複数あるため、コレクションを配列に格納しようと考えたのですが、どうもうまくいかないようです。 さきほど自分はこのように回答しましたが、間違いです。すみません。 上記にあるスクリプトのままだと、1つの絵文字を複数のinputにいれようとしてしまいますね、、、 documentgetelementbyid,document.querySelectorだと逆にひとつの要素しか取得せず、複数の投稿画面の場合に対応できませんし、、 すみません、やり方が思いつきません。。。
maisumakun

2021/08/27 01:06

> 紐づけている部分は下記となります。 元の回答にあるように、これでは全部取れてしまいます。ボタンと入力をどのように対応付けるのか、まずは「ルール」を考えてください。ルールが決まってから、そのルールをコードに起こします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問