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

Vue3使用contenteditable打造定制化輸入

 更新時間:2023年12月08日 09:00:09   作者:coderzry  
contenteditable 屬性為網(wǎng)頁開發(fā)者提供了一種靈活的方式來創(chuàng)建可編輯的內(nèi)容區(qū)域,使用戶可以直接在網(wǎng)頁上進(jìn)行內(nèi)容編輯,而無需依賴傳統(tǒng)的輸入框,本文將利用contenteditable打造定制化輸入,感興趣的可以了解下

定義

全局屬性 contenteditable 是一個枚舉屬性,表示元素是否可被用戶編輯。如果可以,瀏覽器會修改元素的組件以允許編輯。

該屬性必須是下面的值之一:

  • true 或空字符串,表示元素是可編輯的。
  • false 表示元素不是可編輯的。
  • plaintext-only 表示元素的原始文本是可編輯的,但富文本格式會被禁用。 contenteditable 是一個 HTML 屬性,可以應(yīng)用于 HTML 元素,使其成為可編輯的區(qū)域。通過使用 contenteditable 屬性,可以實(shí)現(xiàn)在網(wǎng)頁中編輯文本內(nèi)容的功能,類似于在富文本編輯器中進(jìn)行編輯。

主要特點(diǎn)

可以實(shí)現(xiàn)富文本編輯功能,包括插入圖片、編輯文字樣式(如加粗、斜體、下劃線等)、創(chuàng)建鏈接等。

允許用戶在網(wǎng)頁中直接編輯文本內(nèi)容,而無需使用表單輸入框或富文本編輯器。

可以與 JavaScript 事件結(jié)合使用,如input事件、keydown事件等,以便在用戶輸入時進(jìn)行相應(yīng)的處理。

項目實(shí)戰(zhàn)

最近遇到一個需求,要求表格的內(nèi)容可編輯,項目使用的 vue3.2 版本。其實(shí)這個需求使用input也可以實(shí)現(xiàn),但是還得各種覆蓋樣式,很早之前也聽說過contenteditable這個屬性,這次正好借機(jī)體驗(yàn)一下,廢話不多說,直接封裝一個組件。

template 部分

<template>
  <span contenteditable :innerHTML="content" @input="updateContent" class="custom-contenteditable"></span>
</template>

Js部分

<script setup>
import { ref, watch } from 'vue';
const props = defineProps(['content']);
const emit = defineEmits(['update:content']);
?
const content = ref(props.content);
?
const updateContent = (event) => {
  event.target.innerText = event.target.innerText.replace(/\D/g, ''); // 過濾非數(shù)
  content.value = event.target.innerText;
  emit('update:content', Number(event.target.innerText));
};
?
watch(() => props.content, (newValue) => {
  content.value = newValue;
});
</script>

CSS 部分

<style lang="scss" scoped>
.custom-contenteditable {
  box-sizing: border-box;
  border: 1px solid transparent;
  &:focus {
    outline: 0px;
    border: 1px solid rgb(24, 144, 255) !important;
  }
?
  &:hover {
    border: 1px dashed #aaaaaa;
    transition: all .5s;
  }
}
</style>

組件使用

<ContentEditable v-model:content="item.data" />

最終實(shí)現(xiàn)效果

可以看到,加上一些樣式還是很絲滑的,由于需求原因,只能輸入數(shù)字,因此在@input事件中將輸入值過濾了一遍。如果需要其他格式的,可以對組件進(jìn)一步封裝,拓展對應(yīng)的props即可。

注意事項

在使用時需要格外小心,因?yàn)橛脩艨梢栽诳删庉媴^(qū)域中插入任意 HTML 和 JavaScript 代碼,可能導(dǎo)致安全風(fēng)險。

因?yàn)闉g覽器對 contenteditable 的實(shí)現(xiàn)可能存在差異,因此在跨瀏覽器兼容性方面需要注意。

其他適用場景

  • 富文本編輯器
  • 內(nèi)容管理系統(tǒng)
  • 用戶自定義頁面
  • 電子郵件編輯

瀏覽器兼容性

到此這篇關(guān)于Vue3使用contenteditable打造定制化輸入的文章就介紹到這了,更多相關(guān)Vue3 contenteditable內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • element?ui組件中element.style怎么改詳解

    element?ui組件中element.style怎么改詳解

    element.style是一種內(nèi)聯(lián)樣式,一般都是代碼里寫死的,下面這篇文章主要給大家介紹了關(guān)于element?ui組件中element.style怎么改的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • Vue中render函數(shù)的使用方法

    Vue中render函數(shù)的使用方法

    本篇文章主要介紹了Vue中render函數(shù)的使用方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • Element-ui Image圖片按需引入大圖預(yù)覽

    Element-ui Image圖片按需引入大圖預(yù)覽

    這篇文章主要為大家介紹了Element-ui Image圖片按需引入大圖預(yù)覽實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • vue實(shí)現(xiàn)excel文件導(dǎo)入導(dǎo)出操作示例

    vue實(shí)現(xiàn)excel文件導(dǎo)入導(dǎo)出操作示例

    這篇文章主要為大家介紹了vue實(shí)現(xiàn)excel文件的導(dǎo)入導(dǎo)出實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • vuex通過getters訪問數(shù)據(jù)為undefined問題及解決

    vuex通過getters訪問數(shù)據(jù)為undefined問題及解決

    這篇文章主要介紹了vuex通過getters訪問數(shù)據(jù)為undefined問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue項目因內(nèi)存溢出啟動報錯的解決方案

    vue項目因內(nèi)存溢出啟動報錯的解決方案

    這篇文章主要介紹了vue項目因內(nèi)存溢出啟動報錯的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-09-09
  • 詳解vue-cli 本地開發(fā)mock數(shù)據(jù)使用方法

    詳解vue-cli 本地開發(fā)mock數(shù)據(jù)使用方法

    這篇文章主要介紹了詳解vue-cli 本地開發(fā)mock數(shù)據(jù)使用方法,如果后端接口尚未開發(fā)完成,前端開發(fā)一般使用mock數(shù)據(jù)。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • Vue使用Ref跨層級獲取組件的步驟

    Vue使用Ref跨層級獲取組件的步驟

    這篇文章主要介紹了Vue使用Ref跨層級獲取組件的步驟,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2021-01-01
  • 淺談vue3在項目中的邏輯抽離和字段顯示

    淺談vue3在項目中的邏輯抽離和字段顯示

    本文主要介紹了vue3在項目中的邏輯抽離和字段顯示,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Vue+TailWindcss實(shí)現(xiàn)一個簡單的闖關(guān)小游戲

    Vue+TailWindcss實(shí)現(xiàn)一個簡單的闖關(guān)小游戲

    本文將利用Vue+TailWindcss實(shí)現(xiàn)一個簡單的闖關(guān)小游戲,玩家須躲避敵人與陷阱到達(dá)終點(diǎn)且擁有多個關(guān)卡,感興趣的小伙伴可以了解一下
    2022-04-04

最新評論