[译]用CSS来禁止文本选择_html/css_WEB-ITnose

php中文网
发布: 2016-06-21 09:04:21
原创
1389人浏览过

原文:disable text selection with css

有些时候我们需要禁止网页的部分文本不能被选择。你可以使用user-select这个css特性来实现这个需求。

举例

下面是一个使用了disable-selection类的样式规则,当它作用于一个HTML元素的时候,它会让我们不能够选择这个元素。

.disable-selection{    -moz-user-select:none; /* Firefox */     -ms-user-select:none; /* Internet Explorer */   -ktml-user-select:none; /* KHTML浏览器(比如:Konqueror) */ -webkit-user-select:none; /* Chrome,Safari,and Opera */   -webkit-touch-callout:none; /* Disable Android and IOS callout */}
登录后复制

关于这些样式的一些细节的解释:

  • -webkit-user-select是给Chrome,Safari和Opera用的(并不需要使用-o-user-select)。

  • 没有前缀的user-select是被故意略去的。

    立即学习前端免费学习笔记(深入)”;

  • -webkit-touch-callout属性可以让在移动设备上的触摸后弹出失效。就像下面的这些,我们可以让它们不能出现。

演示

查看演示

要时常记住的

有一个陷阱就是:user-select并不是W3C规范中标准的CSS特性。尽管user-select通过添加浏览器前缀有很好的浏览器支持。

微软文字转语音
微软文字转语音

微软文本转语音,支持选择多种语音风格,可调节语速。

微软文字转语音 0
查看详情 微软文字转语音

前面的例子中,我没有使用没有前缀的user-select特性声明。那是因为在web标准中根本就没有这个属性。我们可以对它的使用类比于于IE专有的CSS属性ms-filter或者-ms-text-kashida-space的属性的使用。

其他需要注意的地方:

  • user-select是有问题并且是不稳定的。有些时候你依然还是可以选择文本,特别是当你从没有被屏蔽掉文本选择的文本的那部分开始选择。

  • 使用全选快捷键有些时候还是会把屏蔽文本选择(Win:Ctrl+A/Mac:Cmd+A)。这种情况你可以在IE11中清楚的了解到。

  • 这不是一种万全的保证文本不被选择的策略。CSS能够很容易被屏蔽。这种技巧依赖于非标准的CSS特性,这意味着未来对这个属性的可持续支持上面存在着很大的不确定性。

  • 屏蔽掉文本选择是很恼人的。我会在渐进提升的过程中使用这个技巧:只有当它可以提高使用支持这个user-select特性的浏览器和设备的用户的用户体验的时候才使用它。但是,我绝不会把它设置成一个大范围的CSS选择器像全部选择器(*)或者body.

  • 这个user-select特性可能会让你的样式表失效。如果遵循标准对你来说非常重要,使用这个属性会在你使用规范测试比如说CSS Validation Service的使用出现问题

浏览器支持

更新于:2015年3月

浏览器 版本支持(以上)
Chrome 6
Firefox 2
IE 10
Safari 3.1

移动端

浏览器 版本支持(以上)
Chrome(Android) 2.1
Safari(IOS) 3.2
HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号