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

Vue通過(guò)字符串關(guān)鍵字符實(shí)現(xiàn)動(dòng)態(tài)渲染input輸入框

 更新時(shí)間:2022年12月08日 16:38:57   作者:我是ed  
這篇文章主要為大家詳細(xì)介紹了Vue如何通過(guò)字符串關(guān)鍵字符實(shí)現(xiàn)動(dòng)態(tài)渲染input輸入框。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下

今天做一個(gè)簡(jiǎn)單的demo,就是有一個(gè)字符串,字符串里面有標(biāo)識(shí)符,前端檢測(cè)到標(biāo)識(shí)符之后,需要將這個(gè)標(biāo)識(shí)符轉(zhuǎn)換成一個(gè) input 輸入框并且進(jìn)行數(shù)據(jù)輸入和綁定功能。

問題描述

就比如現(xiàn)在有這樣一個(gè)字符串:

你好,我是{name},我今年{age} 歲,我喜歡的運(yùn)動(dòng)是{play}。

前端需要把 {xxx} 及其包裹的內(nèi)容轉(zhuǎn)變成一個(gè)輸入框渲染出來(lái),并且呢,當(dāng)在輸入框輸入數(shù)據(jù)的時(shí)候,需要對(duì)輸入的內(nèi)容進(jìn)行獲取。即,轉(zhuǎn)變成下面的樣子進(jìn)行展示:

當(dāng)然可以再此基礎(chǔ)上進(jìn)行一些其他功能的開發(fā),今天主要說(shuō)一下這個(gè)功能的實(shí)現(xiàn)。

{ xxx } 標(biāo)識(shí)字符渲染Dom

組件設(shè)計(jì)

首先我們把這個(gè)功能編寫成一個(gè)簡(jiǎn)單的組件,這個(gè)組件的功能很簡(jiǎn)單,就是接受父組件傳進(jìn)來(lái)的字符串,檢測(cè)到 { } 包裹的數(shù)據(jù),把對(duì)應(yīng)的部分渲染為 input 輸入框,并且可以對(duì)這個(gè)父組件傳進(jìn)來(lái)的字符串?dāng)?shù)據(jù)進(jìn)行修改。

組件開發(fā)

OK,我們先編寫一個(gè)組件。首先先實(shí)現(xiàn)一個(gè)曉得功能,接受父組件傳遞進(jìn)來(lái)的字符串,然后把 { } 包裹的數(shù)據(jù)解析成 input 輸入框展示出來(lái)。

組件很簡(jiǎn)單,html 標(biāo)簽的話,就是使用一個(gè)簡(jiǎn)單的 p 標(biāo)簽,因?yàn)槲覀兪鞘褂玫?vue 開發(fā),我們需要?jiǎng)討B(tài)的渲染 dom 節(jié)點(diǎn)的話,我們可以使用 vue 的 v-html 進(jìn)行渲染。

<p class="title" v-html="domRender(strData)"></p>

這段代碼很簡(jiǎn)單,但是一定要注意是 v-html,然后綁定了一個(gè)方法 domRender,其中回調(diào)傳進(jìn)去的 strData 參數(shù)是父組件傳進(jìn)子組件的字符串?dāng)?shù)據(jù)對(duì)象。

比如說(shuō)父組件中有一個(gè)數(shù)組:

dataList: [{
  index: 1,
  data: "你好,我是{name},我今年{age} 歲,我喜歡的運(yùn)動(dòng)是{play}。"
}],

我們需要把這個(gè)列表的第一個(gè)對(duì)象傳遞給我們的處理子組件。

首先子組件需要一個(gè) props 接受父組件傳進(jìn)的字符串對(duì)象:

  props: {
    str: {
      type: Object,
      required: false,
    },
  },

因?yàn)槲覀兒笃诳赡苄枰薷倪@個(gè)字符串內(nèi)容,所以說(shuō)呢,我們借助計(jì)算屬性,來(lái)處理一下這個(gè)字符串對(duì)象。提前聲明一個(gè) currData 變量為 null 。

  computed: {
    strData: {
      get() {
        if (this.currData) {
          return this.currData
        } else {
          return this.str
        }
      },
      set(value) {
        this.currData = value
      }
    }
  },

OK,上面這個(gè)代碼都很簡(jiǎn)單,就不需要過(guò)多的解釋了哈。上面這一部分和我們單純渲染 input 關(guān)系不大。

重點(diǎn)

最重要的部分來(lái)了,就是將 { } 的部分,渲染成 input 輸入框,首先呢,我們肯定是使用正則表達(dá)式,獲取到 { } 部分,然后用 input 替換一下就可以了。

domRender(str) {
  let strData = str
  var reg = /\{.*?\}/g
  strData = strData.replace(reg, '<input class="emptyOut" type="text" />');
  return strData
},

OK,就上面四行代碼,就成功的把 { } 渲染成 input 輸入框了。

但是!有問題!

【思考】我們成功的把數(shù)據(jù)渲染成了 dom 顯示在頁(yè)面了,但是渲染的目的是啥?數(shù)據(jù)的輸入??!我有一個(gè)表單,我想把 你好,我是{name},我今年{age} 歲,我喜歡的運(yùn)動(dòng)是{play}。 中 {name} 渲染成的輸入框中輸入的數(shù)據(jù),綁定到表單的 name 字段,{age} 渲染成的輸入框中輸入的數(shù)據(jù),綁定到表單的 age字段,play 字段同理。這時(shí)候就發(fā)現(xiàn),我們可以輸入內(nèi)容,但是沒法綁定?。≡趺崔k!

【解答】對(duì)嘍!一下就反應(yīng)過(guò)來(lái)了吧,我們給這個(gè)輸入框綁定一個(gè)屬性值,然后我們?cè)谳斎肟蜉斎胪陻?shù)據(jù)之后,比如焦點(diǎn)消失,我們就可以獲取這個(gè)輸入框?qū)ο螅缓蟾鶕?jù)綁定的屬性,就可以獲取要在表單中綁定的字段和值是什么了。

OK,這個(gè)時(shí)候,我們就需要遍歷每一個(gè)輸入框,然后獲取這個(gè) { } 中的字段,然后綁定成 input 輸入框綁定的屬性值就可以了。

    domRender(str) {
      let strData = str
      var reg = /\{.*?\}/g
      let result = str.match(reg)
      if (!result) {
        return strData
      }
      for (let i = 0; i < result.length; i++) {
        let a = result[i]
        if (a == '{}') {
          continue
        }
        let r = str.match(a)[0]
        let id = r.slice(1, -1)
        strData = strData.replace(r, '<input idData=' + id + ' class="emptyOut" type="text" />');
      }
      return strData
    },

好的,這樣的話,我們就給輸入框綁定了一個(gè)屬性,屬性值就是要綁定的表單字段。

好!完成!已經(jīng)成功綁定。

接下來(lái),就是我們輸入數(shù)據(jù)之后,獲取輸入框數(shù)據(jù)的值,然后把內(nèi)容返回給父組件就可以了。

輸入完成事件

首先,在父組件有一個(gè)表單數(shù)據(jù):

form:{}

子組件輸入完成之后,子組件把輸入好的數(shù)據(jù)傳遞給父組件,父組件將子組件傳遞回來(lái)的數(shù)據(jù)保存到 fom 就可以啦!

其實(shí)很簡(jiǎn)單的我們只需要監(jiān)聽輸入框輸入完成就可以了吧!怎么監(jiān)聽呢,其實(shí)很麻煩,我也是試了好幾種方案。

首先我們界面有一個(gè)按鈕,點(diǎn)擊按鈕的時(shí)候執(zhí)行一個(gè)方法,獲取綁定的值。

<el-button type="success" @click="printData()" size="mini">打印數(shù)據(jù)</el-button>

關(guān)鍵是 printData() 方法里面怎么寫?

我們?cè)谥皠?dòng)態(tài)渲染的時(shí)候都給 input 設(shè)置了一個(gè) class 屬性對(duì)吧?我們點(diǎn)擊事件里面,肯定可以獲取這些 input 框吧!那么我們就可以獲取這些輸入框綁定的屬性和輸入的值吧?

    printData() {
      let data = {}
      const elements = document.getElementsByClassName("emptyOut");
      for (let i = 0; i < elements.length; i++) {
        const item = elements[i]
        data[item.attributes.idData.value] = item.value
      }
      console.log('數(shù)據(jù)---->> ', data)
    }

好,這樣的話我們就可以獲取到輸入框輸入的值了。然后子組件把數(shù)據(jù)傳遞給父組件就可以了,父組件怎么處理在寫響應(yīng)的邏輯就可以了吧!OK,就這樣。

OK,這是一個(gè)方式哈。還有一種哈,稍微說(shuō)一下。

上面是點(diǎn)擊按鈕獲取數(shù)據(jù),還有一個(gè)是使用 @input 方法。

<p class="title"  @input="addComment($event)" v-html="domRender(strData)"></p>

在相應(yīng)的標(biāo)簽上添加 input 事件。

	// 修改輸入框文本數(shù)據(jù)
    addComment(event) {
      console.log("--->> ", event.target.attributes.idData.value, event.target.value)
    },

這樣的話,我們每次修改輸入框內(nèi)容的時(shí)候,都會(huì)打印出我們這個(gè)輸入框的數(shù)據(jù)值。

看效果,還可以哈!拿到數(shù)據(jù)值了,怎么使用就看具體業(yè)務(wù)了。

動(dòng)態(tài)編輯文本

上面我們說(shuō)了,給一個(gè)字符串,把關(guān)鍵內(nèi)容使用 dom 輸入框渲染,現(xiàn)在在做一個(gè)小功能,就是可以手動(dòng)編輯文本。

上面我們接受父組件傳進(jìn)來(lái)數(shù)據(jù)是使用計(jì)算屬性得到的值 strData。所以我們寫一個(gè)輸入框綁定要輸入的內(nèi)容,也就是這個(gè) strData 。在寫一個(gè)按鈕,點(diǎn)擊按鈕的時(shí)候切換編輯和預(yù)覽就可以了。很簡(jiǎn)單沒啥好說(shuō)的。

<template>
  <div class="dom-item">
    <el-input v-show="!preview" type="textarea" :rows="2" placeholder="請(qǐng)輸入內(nèi)容" v-model="strData">
    </el-input>
    <p class="title" v-show="preview" @input="addComment($event)" v-html="domRender(strData)"></p>
    <button class="dom-btn" @click="preview = !preview"> {{ preview ? '編輯' : '預(yù)覽' }}</button>
  </div>
</template>

然后看一下效果。

然后需要處理什么邏輯自己去根據(jù)需求實(shí)現(xiàn)就可以了。

完成?。。?/p>

其實(shí)還有一些細(xì)節(jié)或者是優(yōu)化的地方,因?yàn)樵趯?shí)際開發(fā)過(guò)程中,會(huì)發(fā)現(xiàn)我寫的這些并不是所有的功能都能實(shí)現(xiàn),或者是實(shí)現(xiàn)的不是很好,因?yàn)檫€有一部分我沒有說(shuō),不想說(shuō)了,這一塊描述起來(lái)太復(fù)雜,但是呢,如果真的想實(shí)現(xiàn)的話,自己寫的話就會(huì)發(fā)現(xiàn)這個(gè)問題自己能解決了也就,我說(shuō)有點(diǎn)多余。

到此這篇關(guān)于Vue通過(guò)字符串關(guān)鍵字符實(shí)現(xiàn)動(dòng)態(tài)渲染input輸入框的文章就介紹到這了,更多相關(guān)Vue動(dòng)態(tài)渲染input輸入框 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • webpack開發(fā)vue-cli的項(xiàng)目實(shí)踐

    webpack開發(fā)vue-cli的項(xiàng)目實(shí)踐

    本文主要介紹了webpack開發(fā)vue-cli的項(xiàng)目實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • Vue雙向綁定詳解

    Vue雙向綁定詳解

    這篇文章主要介紹了Vue 實(shí)現(xiàn)雙向綁定的四種方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧,希望能夠給你帶來(lái)幫助
    2021-11-11
  • 一文帶你上手Vue新的狀態(tài)管理Pinia

    一文帶你上手Vue新的狀態(tài)管理Pinia

    Vuex 作為一個(gè)老牌 Vue 狀態(tài)管理庫(kù),大家都很熟悉了,Pinia 是 Vue.js 團(tuán)隊(duì)成員專門為 Vue 開發(fā)的一個(gè)全新的狀態(tài)管理庫(kù),本文就來(lái)講講它的具體使用吧
    2023-04-04
  • Vue中router-link如何添加mouseover提示

    Vue中router-link如何添加mouseover提示

    這篇文章主要介紹了Vue中router-link如何添加mouseover提示,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 詳解vue修改elementUI的分頁(yè)組件視圖沒更新問題

    詳解vue修改elementUI的分頁(yè)組件視圖沒更新問題

    這篇文章主要介紹了詳解vue修改elementUI的分頁(yè)組件視圖沒更新問題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Vue.js實(shí)現(xiàn)表格渲染的方法

    Vue.js實(shí)現(xiàn)表格渲染的方法

    今天小編就為大家分享一篇對(duì)Vue.js實(shí)現(xiàn)表格渲染的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • vue登錄以及權(quán)限驗(yàn)證相關(guān)的實(shí)現(xiàn)

    vue登錄以及權(quán)限驗(yàn)證相關(guān)的實(shí)現(xiàn)

    這篇文章主要介紹了vue登錄以及權(quán)限驗(yàn)證相關(guān)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • vue中使用/deep/失效的解決方法

    vue中使用/deep/失效的解決方法

    這篇文章主要介紹了vue中使用/deep/失效的解決辦法,使用了css預(yù)處理器,則可以使用/deep/, 如果/deep/ 無(wú)效,則使用 ::v-deep,本文給大家講解的非常詳細(xì)需要的朋友可以參考下
    2022-11-11
  • Vue生產(chǎn)環(huán)境調(diào)試的方法步驟

    Vue生產(chǎn)環(huán)境調(diào)試的方法步驟

    開發(fā)環(huán)境下Vue會(huì)提供很多警告來(lái)幫你對(duì)付常見的錯(cuò)誤與陷阱,而在生產(chǎn)環(huán)境下,這些警告語(yǔ)句卻沒有用,反而會(huì)增加應(yīng)用的體積,下面這篇文章主要給大家介紹了關(guān)于Vue生產(chǎn)環(huán)境調(diào)試的方法步驟,需要的朋友可以參考下
    2022-04-04
  • nuxt.js寫項(xiàng)目時(shí)增加錯(cuò)誤提示頁(yè)面操作

    nuxt.js寫項(xiàng)目時(shí)增加錯(cuò)誤提示頁(yè)面操作

    這篇文章主要介紹了nuxt.js寫項(xiàng)目時(shí)增加錯(cuò)誤提示頁(yè)面操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-11-11

最新評(píng)論