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

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

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

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

Q&A

解決済

2回答

2503閲覧

【JavaScript】右クリックメニューを右クリックせずに出す方法

flandre

総合スコア10

JavaScript

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

0グッド

0クリップ

投稿2021/11/19 09:49

右クリックメニューを画面上の操作に頼ることなくスクリプト上の操作のみで出す方法を模索しているのですが
下のようにスクリプトから右クリックイベントを生成&送出しても、コンソール上ではちゃんと右クリックイベントが発行されているのに何故か右クリックメニューが表示されません

HTML

1<div id="hoge">hoge</div>

JavaScript

1const hoge = document.getElementById('hoge'); 2hoge.addEventListener('contextmenu', () => { 3 console.log('yes'); 4}) 5 6setTimeout(() => { 7 //右クリックイベントを生成 8 let event = new MouseEvent('contextmenu'); 9 //生成したイベントをhogeに送出 10 hoge.dispatchEvent(event); 11}, 2000);

この問題の原因、または別のやり方でスクリプトから右クリックメニューを出す方法をご存知の方がいましたら教えて頂きたいです

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

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

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

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

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

guest

回答2

0

“本当の” ユーザイベントであることを伝える方法があります。

本当のユーザアクションから来たイベントの場合、プロパティ event.isTrusted は true になります。スクリプトで生成されたイベントは false です。
カスタムイベントのディスパッチ

セキュリティの問題で、スクリプトで作成したイベントを「デフォルトイベントだと騙す方法」はないと考えていいと思います。

投稿2021/11/19 10:05

Lhankor_Mhy

総合スコア36163

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

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

flandre

2021/11/19 11:00 編集

回答ありがとうございます! なるほど…。納得の理由です ただ一つ疑問なのが、isTrustedがfalseの場合であってもイベント自体はきちんと発火しているみたいで 試しに他の命令をしてみてもちゃんと実行されているようなのですが、この違いは何なんでしょうか? 何故下記のような命令は通されるのに、メニュー表示は弾かれるのでしょうか hoge.addEventListener('contextmenu', () => { console.log('yes'); //命令を追加 const div = document.createElement('div'); hoge.appendChild(div); div.textContent = 'new div'; })
Lhankor_Mhy

2021/11/20 02:13 編集

よく考えると、コンテクストメニューはブラウザではなくてOSレベルの話なので、もしかすると isTrusted は関係なかったかもですね。「それは別物」という yambejp さんのご回答の方が妥当そうです。
flandre

2021/11/20 07:53

なるほど、コンテクストメニューはwindowsに設定されている機能なんですね 別物とおっしゃられていた意味が理解できました 回答ありがとうございます!
guest

0

ベストアンサー

dispatchEventすればイベントを付加することはできますがそれは
contextmenuを実際におこなったのとは別の挙動です

javascript

1<script> 2HTMLElement.prototype.trigger=function(eventStr){ 3 const e = new CustomEvent("HTMLEvents"); 4 e.initEvent(eventStr, true, true ); 5 return this.dispatchEvent(e); 6}; 7document.addEventListener('mouseover',e=>{ 8 if(e.target.closest('#hoge')){ 9 console.log(e.type); 10 e.target.trigger('contextmenu'); 11 } 12}); 13document.addEventListener('contextmenu',e=>{ 14 console.log(e.type); 15}); 16 17</script> 18<div id="hoge">hoge</div>

投稿2021/11/19 11:04

編集2021/11/19 11:04
yambejp

総合スコア115012

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

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

flandre

2021/11/19 11:13

回答ありがとうございます! なるほど…contextmenuを実際に行ったときの挙動をスクリプトで再現することは不可能なのでしょうか?
yambejp

2021/11/19 11:22

> スクリプトで再現することは不可能なのでしょうか? それはLhankor_Mhyさんの回答のとおりできません。 click()やsubmit()などメソッドで用意されているもの以外は無理でしょう
flandre

2021/11/19 11:39

何故contextmenuにはメソッドが用意されてないんでしょうか… ともあれ回答ありがとうございます
flandre

2021/11/20 07:55

丁寧に回答して頂きありがとうございます 右クリックメニューをスクリプトで出すことは諦めて、別の方法を模索しようと思います 自分一人では何故メニューが出ないのか分からず延々と悪戦苦闘していたと思うので、失敗の原因を早々に知れて凄く助かりました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問