微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

HTML5选择文本,鼠标在可拖动的div上

在下面的代码中,我希望能够选择带有鼠标的文本,而无需移动父div. (没有jQuery)
<div draggable="true">
    <input type="text" value="This is text to select">
</div>

解决方法

我的建议是,输入元素有一个onblur和onfocus事件,它会切换对象的draggable属性.这是我的测试代码我有用:
<style>
    #dragObject{background-color: grey; padding: 80px 20px; width: 175px;}
</style>

<div id="dragObject" draggable="true">
    <input type="text" value="This is text to select" onfocus="entering()" onblur="leaving()">
</div>

<script>
function entering(){
    document.getElementById('dragObject').setAttribute("draggable","false");
}

function leaving(){
    document.getElementById('dragObject').setAttribute("draggable","true");
}
</script>

使用此解决方案,您的可拖动div必须大于输入,因为必须有一个位置,您可以在模糊输入时单击以进行拖动.虽然这甚至不应该是一个缺点,但从UX的角度来看,你至少需要一个标签或图标或东西来抓住.否则你就必须开始做一些奇怪的事情,比如“如果你点击并按住一秒或更长时间,你就打算拖动,否则你将会选择文字”.哪个,可以从代码视图中进行,但可能是一个糟糕的用户界面选择.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。