JavaScript 劃詞是指用戶在頁面上劃選文本時,響應該事件并對所選文本進行處理。這種技術常用于引出一個浮層框,顯示相關信息或操作。一個簡單的例子是在有些在線小說網站上,當用戶選中一個人物名字時,會彈出一個框,顯示該角色的詳細資料。
document.addEventListener('mouseup', function () { const selected = window.getSelection().toString(); if (selected.length) { console.log('Selected:', selected); } });
以上代碼響應了鼠標松開(mouseup)事件。在該事件處理函數中,我們首先取得用戶所選的文本,這里使用了 window.getSelection() 方法。如果該文本非空,我們將其打印到控制臺中。
對于一些需要有用戶交互的數據呈現,減少頁面的跳轉以及增強用戶體驗是極為重要的。比如,我們可以實現一個搜索功能:當用戶選中了需要搜索的關鍵詞時,直接彈出搜索框方便用戶進行操作。下面是一個簡單的實現:
let searchBox; document.addEventListener('mouseup', function () { const selected = window.getSelection().toString(); if (selected.length) { searchBox || (searchBox = document.createElement('div')); searchBox.textContent = `您選擇了:"${selected}",請開始搜索。`; searchBox.style = 'position: fixed; top: 10px; right: 10px; padding: 10px; border: 1px solid #ccc; background-color: #f1f1f1; z-index: 999;'; document.body.appendChild(searchBox); } });
在以上代碼中,選中需要搜索的關鍵詞后,我們創建一個 div 元素(第一次創建),并設置其內容和樣式,最后將其添加到頁面的 body 元素內。下一次用戶選中關鍵詞時,我們將更新該 div 的內容以及顯示新的位置。
上面這個例子十分簡單,但可以擴展到更高級的實現,例如讓用戶進行一些高級的查詢,或是使用其他更復雜的 ui 組件呈現查詢結果。
在實際的開發中,我們也會遇到一些復雜的問題。例如,如果用戶在選擇文本時同時拖動了滾動條,該怎么處理呢?我們需要凍結滾動條的狀態,并在選擇結束時進行恢復。下面是一個方法:
function freezeScroll() { document.documentElement.style.overflow = 'hidden'; document.body.style.overflow = 'hidden'; document.documentElement.style.height = '100%'; document.documentElement.style.width = '100%'; document.body.style.height = '100%'; document.body.style.width = '100%'; } function unfreezeScroll() { document.documentElement.style.overflow = 'auto'; document.body.style.overflow = 'auto'; document.documentElement.style.height = ''; document.documentElement.style.width = ''; document.body.style.height = ''; document.body.style.width = ''; } document.addEventListener('mousedown', function () { if (event.button === 0) { freezeScroll(); } }); document.addEventListener('mouseup', function () { if (event.button === 0) { unfreezeScroll(); } });
以上代碼在 mousedown 和 mouseup 事件中,檢測鼠標左鍵并且進行滾動條狀態恢復的操作。需要注意的是,我們需要同時修正 html 和 body 的狀態,以確保樣式正確應用。
最后,值得注意的是,在實現 JavaScript 劃詞時,需要考慮對性能產生的影響。因為每個事件都會觸發瀏覽器的重繪和重排操作,對于頁面內容復雜的情況,可能會產生非常明顯的卡頓。因此,在實現時需要控制事件的頻率以及合理利用緩存等技術手段優化性能。