Google Chrome浏览器的“user-select:element”解决方法?

时间:2014-02-24 09:00:58

标签: javascript css google-chrome

我正在开发一个gui工具,可以选择文本框,拖动文本框并编辑内容。考虑在绘图程序(如powerpoint)中进行文本编辑。我对文本选择有一些非常具体的要求。我需要确保在其中一个框中选择文本时,选择不会扩展到其他相邻框中的文本。

好消息是有一种方法可以做到这一点,坏消息是它只是IE,我需要为Chrome找到一种解决方法。

user-select: element

  

仅在Internet Explorer中受支持。允许选择   从元素开始;但是,选择将包含在内   该元素的界限。

我猜测解决方法需要做一些事情,比如监听selectstart,selectchange事件,调用preventDefault(),并手动操作选择对象。

任何想法都赞赏;)

更新:这是一个主要适用的fiddle。错误是,我需要以某种方式阻止Ctrl-A,并且在窗口外选择和释放鼠标会使其他文本暂时无法选择。不确定如何解决这些问题,任何人?提示风滚草......

HTML

<div id="one" class="textbox">qwe qweqwe <b>werwesd ewrwer</b> fsdfdsrwe fdsfsdf erertre fsdfsdf</div>

<div id="two" class="textbox">dsgdfs dfgdsf dfgdfg dfgdfs <i>dfsgsdf</i> dfsgdfsg</div>

CSS

.textbox {          
    position: absolute;
    -webkit-user-select: text;
    width: 250px;           
    font-size: 30px;
    border: 1px solid black;
}

#one { left: 150px; top: 150px; }
#two { left: 450px; top: 250px; }

JS

document.addEventListener('mousedown', mousedown, false);
document.addEventListener('mouseup', mouseup, false);

// While selecting disallow selection of other text.
function mousedown(event) {
    console.log('mousedown', event.target);         
    var current = findParentTextBox(event.target);
    var list = document.querySelectorAll('.textbox');
    for (var i = 0, textbox; textbox = list[i]; i++) {
        if (textbox != current) {
            textbox.style.webkitUserSelect = 'none';
        }
    }
}

// Once finished selecting allow all text to be selected again.
function mouseup(event) {
    console.log('mouseup', event.target);
    var list = document.querySelectorAll('.textbox');
    for (var i = 0, textbox; textbox = list[i]; i++) {
        textbox.style.webkitUserSelect = 'text';
    }
}

function findParentTextBox(node) {
    while (node != null) {
        if (node.className == 'textbox')
            return node;
        node = node.parent;
    }
    return null;
}

修改

提起了一个铬虫:https://code.google.com/p/chromium/issues/detail?id=346533

1 个答案:

答案 0 :(得分:0)

不确定它是否会干扰您的其他互动需求(拖动需求测试),但iframe可能对您有用。它们具有开箱即用的选择行为(包括全选)。你必须用javascript或外部来源填充它们。 这是你的ifss的jsfiddle(使用js来创建div中的iframe): http://jsfiddle.net/5y8EA/3/

对于可修改的文字,您可以查看contenteditable属性: https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/Content_Editable