在Safari中没有触发JQuery Click事件?

时间:2009-01-23 08:27:00

标签: javascript jquery select safari javascript-events

当用户从选择框中选择一个选项时,我正在尝试做某事 - 尽可能简单吗?我正在使用JQuery 1.3.1注册一个带有选择框id的点击处理程序。一切都很好,直到我使用Chrome和Safari测试,发现它不起作用。

  1. Firefox 3.05 - 是
  2. I.E 7.0.5730.13 - 是
  3. IE6Eolas - 是
  4. Sarafi 3.2.1 - NO
  5. Chrome 1.0.154.43 - 否
  6. 见下面的代码:

    <html>
    <head>
        <script language="javascript" type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.1/jquery.min.js"></script>
        <script language="javascript">
        $(document).ready(function(){
            $('#myoption').click(function() { alert('Select Dropdown was clicked: '+ $('#myoption').val()); });
        });     
        </script>
    </head>
    <body>
        <select id="myoption">
        <option value="A">A</option>
        <option value="B">B</option>
        </select>
    </body>
    </html>
    

    任何人都知道我应该为此工作吗?警报最终会被触发,但只有在双击选择框后才能触发?

2 个答案:

答案 0 :(得分:5)

我发现了我的问题。对于选择框,您需要为“更改”事件而不是“单击”事件注册处理程序。 Firefox和IE使用点击事件很奇怪。

总而言之,以下代码适用于所有浏览器:

<html>
<head>
    <script language="javascript" type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.1/jquery.min.js"></script>
    <script language="javascript">
    $(document).ready(function(){
        $('#myoption').change(function() { alert('Select Dropdown was clicked: '+ $('#myoption').val()); });
    });         
    </script>
</head>
<body>
    <select id="myoption">
    <option value="A">A</option>
    <option value="B">B</option>
    </select>
</body>
</html>

答案 1 :(得分:1)

Safari和Chrome都是基于webkit的浏览器。 Webkit使用操作系统中的本机下拉元素而不是自己实现下拉列表,遗憾的是,本机下拉列表不支持点击事件。出于同样的原因,他们也不支持CSS选项元素或其他巧妙的技巧。

唯一能够实现这些工作的跨浏览器方法是使用&lt; ul&gt;手动实现这一点。还有很多javascript。