CSS user-select 属性(是否允许用户选中文本)

本文操作环境:Windows7系统,CSS3版本,Dell G3电脑。

user-select,设置或检索是否允许用户选中文本

user-select 属性规定是否能选取元素的文本。

在 web 浏览器中,如果您在文本上双击,文本会被选取或高亮显示。此属性用于阻止这种行为。

user-select语法:

user-select:none |text| all | element

默认值:text

适用于:除替换元素外的所有元素

继承性:无

动画性:否

计算值:指定值

属性值:

描述
auto默认。如果浏览器允许,则可以选择文本。
none防止文本选取。
text文本可被用户选取。
all单击选取文本,而不是双击。

说明:

设置或检索是否允许用户选中文本。

IE6-9不支持该属性,但支持使用标签属性 onselectstart="return false;" 来达到 user-select:none 的效果;Safari和Chrome也支持该标签属性;

直到Opera12.5仍然不支持该属性,但和IE6-9一样,也支持使用私有的标签属性 unselectable="on" 来达到 user-select:none 的效果;unselectable 的另一个值是 off;

除Chrome和Safari外,在其它浏览器中,如果将文本设置为 -ms-user-select:none;,则用户将无法在该文本块中开始选择文本。不过,如果用户在页面的其他区域开始选择文本,则用户仍然可以继续选择将文本设置为 -ms-user-select:none; 的区域文本;

对应的脚本特性为userSelect。

兼容性:

浅绿 = 支持

红色 = 不支持

粉色 = 部分支持

实例

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8" />

<title></title>

<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />

<style>

.test{

padding:10px;

-webkit-user-select:none;

-moz-user-select:none;

-o-user-select:none;

user-select:none;

background:#eee;}

</style>

</head>

<body>

<div onselectstart="return false;" unselectable="on">选择我试试,你会发现怎么也选择不到我,哈哈哈哈</div>

</body>

</html>

这段代码结合了css+js,基本上将常用的浏览器都禁止选择了。

1

2

3

4

5

6

7

8

div {

-webkit-user-select: none; /* Safari */

-ms-user-select: none; /* IE 10+ and Edge */

-o-user-select:none;

-moz-user-select:none;/*火狐*/

-khtml-user-select:none;/*早期浏览器*/

user-select: none; /* Standard syntax */

}

浏览器支持

表格中的数字注明了完全支持该属性的首个浏览器版本。

跟随 -webkit-、-ms- 或 -moz- 的数字规定使用前缀的首个版本。

ChromeIE / EdgeFirefoxSafariOpera
54.0
6.0 -webkit-
79.0
10.0 -ms-
69.0
2.0 -moz-
3.1 -webkit-41.0
15.0 -webkit-

文章转自: https://www.cnblogs.com/suducn/p/18190039

  • 32
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值