20
31

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

iOS で、要素をタッチしてもクリックイベントが発生しない問題への対処

Last updated at Posted at 2015-11-30

業務でウェブサイトを作成していて、iPhone、iPadでフローティングの枠外を押した時に閉じる処理が作用しないという問題に遭遇しました。

$(document).on('click', function() {
	// ポップアップを閉じる処理
});

原因

HTMLで通常クリックが期待される要素以外ではイベントが発生しない。
そのため、クリックイベントを書いてもその処理が行われることがない。

クリックされることが期待される要素

button 要素、a 要素など

クリックされることが期待されない要素

div 要素、span 要素、p 要素 など

解決方法

下記の方法だけではありませんが、最も簡単と思われる方法を2つ挙げます。

1. cursor:pointer のスタイルを指定

こちらは問題を調べたらすぐに出てきた解決方法です。
下記の理由からこちらの解決方法をとることはやめました。

  • 実際には見えないが、カーソルが常に指型カーソルになっていると思うと、個人的には気持ち悪い
<style>
.container {
  cursor:pointer;
}
</style>

2. 空のイベントハンドラを指定

html または js にどちらに書いてもかまいませんが、 body よりも下の要素 に指定してください。

htmlに記述する

<div class="container" onclick=""></div>

jsに記述する

$('.container').on('click', function(){});
20
31
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
20
31

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?