欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于Vue實現(xiàn)一個textarea幽靈建議功能

 更新時間:2023年09月02日 14:33:30   作者:60歲咯  
不知道你有沒有發(fā)現(xiàn)Bing AI聊天有個輸入提示功能,在用戶輸入部分內(nèi)容時后面會給出灰色提示文案,用戶只要按下tab鍵就可以快速添加提示的后續(xù)內(nèi)容,我將這個功能稱為幽靈建議,接下來我將用Vue框架來實現(xiàn)這個功能,需要的朋友可以參考下

不知道你有沒有發(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)文章

  • vue3.0中使用element的完整步驟

    vue3.0中使用element的完整步驟

    這篇文章主要給大家介紹了關(guān)于vue3.0中使用element的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • vue前端el-input輸入限制輸入位數(shù)及輸入規(guī)則

    vue前端el-input輸入限制輸入位數(shù)及輸入規(guī)則

    這篇文章主要給大家介紹了關(guān)于vue前端el-input輸入限制輸入位數(shù)及輸入規(guī)則的相關(guān)資料,文中通過代碼介紹的介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • Vue底層實現(xiàn)原理總結(jié)

    Vue底層實現(xiàn)原理總結(jié)

    小編給大家整理Vue底層實現(xiàn)原理的知識點(diǎn)總結(jié),如果大家對此有需要,可以學(xué)習(xí)參考下,希望我們整理的內(nèi)容能夠幫助到你。
    2018-02-02
  • 詳解Vue.js搭建路由報錯 router.map is not a function

    詳解Vue.js搭建路由報錯 router.map is not a function

    這篇文章主要介紹了詳解Vue.js搭建路由報錯 router.map is not a function,非常具有實用價值,需要的朋友可以參考下
    2017-06-06
  • VUE對Storage的過期時間設(shè)置,及增刪改查方式

    VUE對Storage的過期時間設(shè)置,及增刪改查方式

    這篇文章主要介紹了VUE對Storage的過期時間設(shè)置,及增刪改查方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • Vue2.0用 watch 觀察 prop 變化(不觸發(fā))

    Vue2.0用 watch 觀察 prop 變化(不觸發(fā))

    本篇文章主要介紹了Vue2.0用 watch 觀察 prop 變化(不觸發(fā)),非常具有實用價值,需要的朋友可以參考下
    2017-09-09
  • 詳解Vue Elementui中的Tag與頁面其它元素相互交互的兩三事

    詳解Vue Elementui中的Tag與頁面其它元素相互交互的兩三事

    這篇文章主要介紹了詳解Vue Elementui中的Tag與頁面其它元素相互交互的兩三事,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • vue element項目引入icon圖標(biāo)的方法

    vue element項目引入icon圖標(biāo)的方法

    這篇文章主要介紹了vue element項目引入icon圖標(biāo)的方法,本文圖文并茂給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2018-06-06
  • Vue全局注冊中的kebab-case和PascalCase用法

    Vue全局注冊中的kebab-case和PascalCase用法

    這篇文章主要介紹了Vue全局注冊中的kebab-case和PascalCase用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • vue.extend,mixins和vue.component的區(qū)別及說明

    vue.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

最新評論