基于Vue實現(xiàn)一個textarea幽靈建議功能
不知道你有沒有發(fā)現(xiàn)Bing AI聊天有個輸入提示功能,在用戶輸入部分內(nèi)容時后面會給出灰色提示文案。用戶只要按下tab
鍵就可以快速添加提示的后續(xù)內(nèi)容。我將這個功能稱為幽靈建議。接下來我將用Vue框架來實現(xiàn)這個功能。
布局樣式
布局使用label
標(biāo)簽作為容器,這樣即使建議內(nèi)容在上層,也不會影響輸入框的輸入。
<label class="container"> <textarea></textarea> <div class="ghost-content"></div> </label>
樣式需要確保輸入框與建議內(nèi)容容器除了顏色外都要一致。建議內(nèi)容可以通過z-index: -1
置于輸入框底部,但要注意輸入框必須是透明背景。
.container { position: relative; display: block; width: 300px; height: 200px; font-size: 14px; line-height: 21px; } .container textarea { width: 100%; height: 100%; padding: 0; border: 0; font: inherit; color: #212121; background-color: #fff; outline: none; } .ghost-content { position: absolute; left: 0; right: 0; top: 0; bottom: 0; color: #212121; opacity: 0.3; }
顯示邏輯
顯示邏輯比較簡單,當(dāng)輸入框中顯示輸入內(nèi)容時,找到匹配的內(nèi)容后將其顯示在建議容器中。以下是代碼示例:
import { ref } from 'vue' const content = ref('') // 輸入框內(nèi)容 const ghostContent = ref('') // 建議內(nèi)容 const suggestions = ['你好啊', '怎么學(xué)編程'] // 建議列表 const handleInput = () => { ghostContent.value = '' // 內(nèi)容變化時,清空建議 // 如果為空或者建議內(nèi)容改變,則不進(jìn)行后續(xù)匹配 if (content.value === '') { return } const suggestion = suggestions.find((item) => item.startsWith(content.value)) if (suggestion) { ghostContent.value = suggestion } } const handleTabKeydown = () => { // 監(jiān)聽tab鍵按下,將輸入框內(nèi)容設(shè)置為建議內(nèi)容,同時清空建議內(nèi)容 content.value = ghostContent.value ghostContent.value = '' }
按照以上代碼的寫法,已經(jīng)可以實現(xiàn)幽靈建議的功能了。但還存在一個小問題,輸入框內(nèi)容和建議內(nèi)容的重疊部分會顯得比較粗。因此,最好將重疊部分的文字顏色設(shè)置為透明。我的解決方法是使用span
標(biāo)簽來包裹重疊部分的內(nèi)容,然后將span
的文字樣式設(shè)置為透明。此外,為了表示可以使用tab
鍵,我在末尾添加了→
符號。改進(jìn)后的代碼如下:
// 重復(fù)部分省略 // ... const ghostHTML = ref('') // 建議內(nèi)容HTML const handleInput = () => { ghostContent.value = '' ghostHTML.value = '' if (content.value === '' || fromSuggestion) { fromSuggestion && (fromSuggestion = false) return } const suggestion = suggestions.find((item) => item.startsWith(content.value)) if (suggestion) { ghostContent.value = suggestion ghostHTML.value = suggestion.replace(content.value, `<span>${content.value}</span>`) + ' →' // 顯示內(nèi)容替換 } } const handleTabKeydown = () => { content.value = ghostContent.value ghostContent.value = '' ghostHTML.value = '' }
最后,補(bǔ)充一下HTML代碼。
- 我們需要阻止
tab
按下的默認(rèn)事件,按下tab
鍵會導(dǎo)致切換到其他元素,使輸入框失去焦點(diǎn); - 使用
v-html
來綁定HTML內(nèi)容。
到此這篇關(guān)于基于Vue實現(xiàn)一個textarea幽靈建議功能的文章就介紹到這了,更多相關(guān)Vue textarea建議功能內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue前端el-input輸入限制輸入位數(shù)及輸入規(guī)則
這篇文章主要給大家介紹了關(guān)于vue前端el-input輸入限制輸入位數(shù)及輸入規(guī)則的相關(guān)資料,文中通過代碼介紹的介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue具有一定的參考借鑒價值,需要的朋友可以參考下2023-09-09詳解Vue.js搭建路由報錯 router.map is not a function
這篇文章主要介紹了詳解Vue.js搭建路由報錯 router.map is not a function,非常具有實用價值,需要的朋友可以參考下2017-06-06VUE對Storage的過期時間設(shè)置,及增刪改查方式
這篇文章主要介紹了VUE對Storage的過期時間設(shè)置,及增刪改查方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-02-02Vue2.0用 watch 觀察 prop 變化(不觸發(fā))
本篇文章主要介紹了Vue2.0用 watch 觀察 prop 變化(不觸發(fā)),非常具有實用價值,需要的朋友可以參考下2017-09-09詳解Vue Elementui中的Tag與頁面其它元素相互交互的兩三事
這篇文章主要介紹了詳解Vue Elementui中的Tag與頁面其它元素相互交互的兩三事,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09vue element項目引入icon圖標(biāo)的方法
這篇文章主要介紹了vue element項目引入icon圖標(biāo)的方法,本文圖文并茂給大家介紹的非常詳細(xì),需要的朋友可以參考下2018-06-06Vue全局注冊中的kebab-case和PascalCase用法
這篇文章主要介紹了Vue全局注冊中的kebab-case和PascalCase用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03vue.extend,mixins和vue.component的區(qū)別及說明
Vue.extend 創(chuàng)建Vue的子類,可視為組件構(gòu)造函數(shù),Vue.mixin 允許全局添加方法或?qū)傩?方便所有組件使用,Vue.component 是插件注冊方法,通過Vue.extend創(chuàng)建的組件實例可以注冊到Vue全局,使其在任何組件中可用2024-09-09