首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何使HTML文本不可选

如何使HTML文本不可选
EN

Stack Overflow用户
提问于 2010-02-22 20:12:23
回答 4查看 268.8K关注 0票数 212

我想将文本作为标签添加到我的网页中,并使其不可选。

换句话说,当鼠标光标在文本上时,我希望它根本不会变成文本选择光标。

我正在努力实现的一个很好的例子是这个网站上的按钮(问题,标签,用户,...)

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2010-02-22 20:31:45

使用普通的HTML不能做到这一点,因此JSF在这里也不能为您做太多事情。

如果你只针对decent browsers,那么就使用CSS3:

代码语言:javascript
复制
.unselectable {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
代码语言:javascript
复制
<label class="unselectable">Unselectable label</label>

如果您还想涵盖较旧的浏览器,那么可以考虑以下JavaScript回退:

代码语言:javascript
复制
<!doctype html>
<html lang="en">
    <head>
        <title>SO question 2310734</title>
        <script>
            window.onload = function() {
                var labels = document.getElementsByTagName('label');
                for (var i = 0; i < labels.length; i++) {
                    disableSelection(labels[i]);
                }
            };
            function disableSelection(element) {
                if (typeof element.onselectstart != 'undefined') {
                    element.onselectstart = function() { return false; };
                } else if (typeof element.style.MozUserSelect != 'undefined') {
                    element.style.MozUserSelect = 'none';
                } else {
                    element.onmousedown = function() { return false; };
                }
            }
        </script>
    </head>
    <body>
        <label>Try to select this</label>
    </body>
</html>

如果您已经在使用jQuery,那么下面是另一个示例,它将一个新函数disableSelection()添加到jQuery中,这样您就可以在jQuery代码中的任何地方使用它:

代码语言:javascript
复制
<!doctype html>
<html lang="en">
    <head>
        <title>SO question 2310734 with jQuery</title>
        <script src="http://code.jquery.com/jquery-latest.min.js"></script>
        <script>
            $.fn.extend({ 
                disableSelection: function() { 
                    this.each(function() { 
                        if (typeof this.onselectstart != 'undefined') {
                            this.onselectstart = function() { return false; };
                        } else if (typeof this.style.MozUserSelect != 'undefined') {
                            this.style.MozUserSelect = 'none';
                        } else {
                            this.onmousedown = function() { return false; };
                        }
                    }); 
                } 
            });

            $(document).ready(function() {
                $('label').disableSelection();            
            });
        </script>
    </head>
    <body>
        <label>Try to select this</label>
    </body>
</html>
票数 333
EN

Stack Overflow用户

发布于 2011-06-17 15:09:57

这里没有人发布了所有正确的CSS变体的答案,所以这里是:

代码语言:javascript
复制
-webkit-touch-callout: none;
-webkit-user-select: none;
-khtml-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
票数 172
EN

Stack Overflow用户

发布于 2011-11-24 00:04:53

您的问题的完整现代解决方案是纯粹基于CSS的,但请注意,较旧的浏览器不支持它,在这种情况下,您需要退回到其他浏览器提供的解决方案。

所以在纯CSS中:

代码语言:javascript
复制
-webkit-user-select: none;
-khtml-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
-o-user-select: none;
user-select: none;

但是,当鼠标光标停留在元素的文本上时,它仍然会变成一个插入符号,所以你可以添加:

代码语言:javascript
复制
cursor: default;

现代CSS是相当优雅的。

票数 62
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2310734

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档