基于Vue實(shí)現(xiàn)一個(gè)textarea幽靈建議功能
不知道你有沒有發(fā)現(xiàn)Bing AI聊天有個(gè)輸入提示功能,在用戶輸入部分內(nèi)容時(shí)后面會(huì)給出灰色提示文案。用戶只要按下tab鍵就可以快速添加提示的后續(xù)內(nèi)容。我將這個(gè)功能稱為幽靈建議。接下來我將用Vue框架來實(shí)現(xiàn)這個(gè)功能。

布局樣式
布局使用label標(biāo)簽作為容器,這樣即使建議內(nèi)容在上層,也不會(huì)影響輸入框的輸入。
<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)容時(shí),找到匹配的內(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)容變化時(shí),清空建議
// 如果為空或者建議內(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)容,同時(shí)清空建議內(nèi)容
content.value = ghostContent.value
ghostContent.value = ''
}按照以上代碼的寫法,已經(jīng)可以實(shí)現(xiàn)幽靈建議的功能了。但還存在一個(gè)小問題,輸入框內(nèi)容和建議內(nèi)容的重疊部分會(huì)顯得比較粗。因此,最好將重疊部分的文字顏色設(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鍵會(huì)導(dǎo)致切換到其他元素,使輸入框失去焦點(diǎn); - 使用
v-html來綁定HTML內(nèi)容。
到此這篇關(guān)于基于Vue實(shí)現(xiàn)一個(gè)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具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09
詳解Vue.js搭建路由報(bào)錯(cuò) router.map is not a function
這篇文章主要介紹了詳解Vue.js搭建路由報(bào)錯(cuò) router.map is not a function,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-06-06
VUE對Storage的過期時(shí)間設(shè)置,及增刪改查方式
這篇文章主要介紹了VUE對Storage的過期時(shí)間設(shè)置,及增刪改查方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02
Vue2.0用 watch 觀察 prop 變化(不觸發(fā))
本篇文章主要介紹了Vue2.0用 watch 觀察 prop 變化(不觸發(fā)),非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-09-09
詳解Vue Elementui中的Tag與頁面其它元素相互交互的兩三事
這篇文章主要介紹了詳解Vue Elementui中的Tag與頁面其它元素相互交互的兩三事,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-09-09
vue element項(xiàng)目引入icon圖標(biāo)的方法
這篇文章主要介紹了vue element項(xiàng)目引入icon圖標(biāo)的方法,本文圖文并茂給大家介紹的非常詳細(xì),需要的朋友可以參考下2018-06-06
Vue全局注冊中的kebab-case和PascalCase用法
這篇文章主要介紹了Vue全局注冊中的kebab-case和PascalCase用法,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
vue.extend,mixins和vue.component的區(qū)別及說明
Vue.extend 創(chuàng)建Vue的子類,可視為組件構(gòu)造函數(shù),Vue.mixin 允許全局添加方法或?qū)傩?方便所有組件使用,Vue.component 是插件注冊方法,通過Vue.extend創(chuàng)建的組件實(shí)例可以注冊到Vue全局,使其在任何組件中可用2024-09-09

