contenteditable 插入及粘貼純文本內容


  本文主要介紹 div 標簽設置  contenteditable = ' true ' 時,在光標位置插入輸入的內容,或在光標位置粘貼純文本內容。文中涉及知識,可參考以下: http://www.zhangxinxu.com/wordpress/2016/01/contenteditable-plaintext-only/ 

http://www.jb51.net/article/57650.htm 

https://www.cnblogs.com/rainman/archive/2011/02/27/1966482.html

http://www.zhangxinxu.com/wordpress/2011/04/js-range-html%E6%96%87%E6%A1%A3%E6%96%87%E5%AD%97%E5%86%85%E5%AE%B9%E9%80%89%E4%B8%AD%E3%80%81%E5%BA%93%E5%8F%8A%E5%BA%94%E7%94%A8%E4%BB%8B%E7%BB%8D/

http://kjah.iteye.com/blog/422509

  先搭好 html ,一個按鈕用於插入操作,一個 div 實現 contenteditable 功能,及主要邏輯

<button type="button" id='insert'>插入標題</button>
<div contentEditable="true" id="editor">
    <h3>副標題</h3>
    <p>文本</p>
</div>

  接着是實現 js 邏輯功能

document.getElementById('insert').onclick=function(){
    // 點擊插入按鈕時,系統彈框輸入內容
    var content = prompt('請輸入內容');

    // 防止編輯框沒有獲取焦點時點擊,故加一個操作,使編輯框獲取焦點
    document.getElementById('editor').focus();

    // 執行插入方法
    if(!!content){
        insertHtml('<h4>'+content+'</h4>');
    }
}

  主要邏輯在 insertHtml 方法中

function insertHtml(html) {
    //Selection 對象,表示用戶選擇的文本范圍或光標的當前位置。
    //在非IE瀏覽器(Firefox、Safari、Chrome、Opera)下可以使用window.getSelection()獲得selection對象
    //anchor 選中區域的“起點”。
    //focus 選中區域的“結束點”。
    //range 是一種fragment(HTML片斷),它包含了節點或文本節點的一部分。一般情況下,同一時刻頁面中只可能有一個range,也有可能是多個range(使用Ctrl健進行多選,不過有的瀏覽器不允許,例如Chrome)。可以從selection中獲得range對象,也可以使用document.createRange()方法獲得。
    var sel = window.getSelection(), 
        range;

    if (sel.getRangeAt && sel.rangeCount) {
        //getRangeAt(index) 從當前selection對象中獲得一個range對象。
        range = sel.getRangeAt(0);
        //deleteContents()方法,range內容會被刪除
        range.deleteContents();
        //將輸入的內容寫入並加載到 dom 中
        var el = document.createElement("div");
        el.innerHTML = html;
        var frag = document.createDocumentFragment(), node, lastNode;
        while ( (node = el.firstChild) ) {
            lastNode = frag.appendChild(node);
        }
        //insertNode,在range的開始位置插入一 個節點
        range.insertNode(frag);
        //收尾
        if (lastNode) {
            range = range.cloneRange();
            range.setStartAfter(lastNode);
            range.collapse(true);
            sel.removeAllRanges();
            sel.addRange(range);
        }
    }
    
}

  此時往編輯框里粘貼內容,會帶上原本樣式,顯然不是我們要的結果,需對粘貼文本進行更改

document.getElementById('editor').onpaste=function(event){
    var e = event || window.event
    // 阻止默認粘貼
    e.preventDefault();
    // 粘貼事件有一個clipboardData的屬性,提供了對剪貼板的訪問
    // clipboardData的getData(fomat) 從剪貼板獲取指定格式的數據
    var text =  (e.originalEvent || e).clipboardData.getData('text/plain') || prompt('在這里輸入文本');
    // 插入
    document.execCommand("insertText", false, text);
};

  最后附上完整代碼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>contenteditable</title>
    <style>
        #insert{
            width: 90px;
            height: 30px;
            border: 1px solid #ccc;
            background-color: #fff;
            margin: 10px;
        }
        #editor{
            padding: 10px;
            overflow-y: auto;
            min-height:200px; 
            border:1px solid #f33;
            outline: 0;
        }
        #editor h4{
            margin: 10px 0;
        }
    </style>
</head>
<body>

<button type="button" id='insert'>插入標題</button>
<div contentEditable="true" id="editor">
    <h3>副標題</h3>
    <p>文本</p>
</div>
    
</body>
<script>

document.getElementById('insert').onclick=function(){
    var content = prompt('請輸入內容');
    document.getElementById('editor').focus();
    if(!!content){
        insertHtml('<h4>'+content+'</h4>');
    }
}

document.getElementById('editor').onpaste=function(event){
    var e = event || window.event
    e.preventDefault();
    var text =  (e.originalEvent || e).clipboardData.getData('text/plain') || prompt('在這里輸入文本');

    document.execCommand("insertText", false, text);
};

function insertHtml(html) {
    var sel = window.getSelection(), 
        range;

    if (sel.getRangeAt && sel.rangeCount) {
        range = sel.getRangeAt(0);
        range.deleteContents();
        var el = document.createElement("div");
        el.innerHTML = html;
        var frag = document.createDocumentFragment(), node, lastNode;
        while ( (node = el.firstChild) ) {
            lastNode = frag.appendChild(node);
        }
        range.insertNode(frag);
        if (lastNode) {
            range = range.cloneRange();
            range.setStartAfter(lastNode);
            range.collapse(true);
            sel.removeAllRanges();
            sel.addRange(range);
        }
    }
}
</script>
</html>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM