跳到主要內容

iOS Safari 中點擊事件失效的解決辦法(轉貼)





iOS Safari 中點擊事件失效的解決辦法


問題描述

當使用委託給一個元素添加click事件時,如果事件是委託到 document 或 body 上,並且委託的元素是默認不可點擊的(如 div, span 等),此時 click 事件會失效。

可以使用下面的代碼在 iOS 中進行測試。
<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width">
    <title>iOS click bug test</title>

    <style>
        .container {
        }

        .target {
            display: block;
            text-align: center;
            margin: 100px 30px 0;
            padding: 10px 0;
            border: 1px solid #ccc;
        }
    </style>
</head>  
<body>  
    <div class="container">
        <div class="target"> Click Me! </div>
    </div>

    <script src="//code.jquery.com/jquery-2.1.4.min.js"></script>
    <script type="text/javascript">
        // 或者 $(document).on('click', ....)
        $('body').on('click', '.target', function (e) {
            alert('click');
        });
    </script>
</body>  
</html>  

解決辦法

解決辦法有 4 種可供選擇:
  1. ​將 click 事件直接綁定到目標​元素(​​即 .target)上
  2. 將目標​元素換成 <a> 或者 button 等可點擊的​元素
  3. ​將 click 事件委託到​​​​​非 document 或 body 的​​父級元素上
  4. ​給​目標元素加一條樣式規則 cursor: pointer;
推薦後兩種。從解決辦法來看,​推測在 safari 中,不可點擊的元素的點擊事件不會冒泡到父級元素。通過添加 cursor: pointer 使得元素變成了可點擊的了。


出處:https://happycoder.net/solve-ios-safari-click-event-bug/

留言

這個網誌中的熱門文章

Android 在Fragment下控制輸入鍵盤

jQuery獲取Select選擇的Text和Value(轉)

彈跳視窗iframe的運用