Firefox/Opera 不支持 onselectstart事件的解决方法

发布时间:2020-04-03编辑:脚本学堂
介绍下,解决FirefoxOpera不支持onselectstart函数-moz-user-select non的方法,有需要的朋友参考下。

实际的编程中,很多地方不允许用户select,在IE/Safari/Chrome中,可以使用onselectstart事件来阻止用户选定元素内文本,但在火狐中,这段区域还是可以选择的。
例如:
 

复制代码 代码示例:

<html>
<head>
    <meta charset="gbk">
    <title>Firefox/Opera不支持onselectstart事件-www.jb200.com</title>
</head>

<body>
    <div id="noselect">Text</div>
    <script type="text/javascript">
        var div = document.getElementById('noselect');
        div.onselectstart = function () {
            console.log(3);
        }
    </script>
</body>
</html>

当用鼠标去选定div内的文本时,IE/Safari/Chrome 的控制台输出了3,Firefox/Opera则没有输出。
但是火狐有自己的css样式"-moz-user-select“
我们可以使用它来禁止用户选择文本

如下:
 

<html>
<head>
    <meta charset="gbk">
    <title>Firefox/Opera不支持onselectstart事件</title>
    <style type="text/css">
        #noselect
        {
            -moz-user-select: none;
            cursor: default;
        }
    </style>
</head>

<body>
    <div id="noselect" onselectstart="return false;">Text</div>
</body>
</html>

注意:user-select是css3 的样式