suchen

Heim  >  Fragen und Antworten  >  Hauptteil

V-Modell auf der Div-Tag-Komponente

Die Verwendung von v-modeldiv 标记时出现问题。显然, div 标签不允许 v-model ,我决定将我的评论部分创建为组件。由于 UI/UX 原因,我需要按原样分配此 div 文本区域。 textareainput 等标签,据我所知,这些标签与 contenteditable="true" ist nicht kompatibel. Ich muss die Höhe des Eingabefelds erweitern, wenn der Benutzer einen Kommentar eingibt. Unten ist die Vue-Komponente, die ich in die übergeordnete Ansicht importiert habe.

<!-- CommentSection.vue -->
<template>
    <div id="chatId" contenteditable="true" placeholder="Leave a message" class="overflow-hidden block mx-4 text-left p-2.5 w-full text-sm text-gray-900 bg-white rounded-2xl border border-gray-300 focus:ring-blue-500 focus:border-blue-500"/>
</template>

<style>
#chatId[contenteditable="true"]:empty:not(:focus):before {
    content: attr(placeholder)
}
</style>

In meiner Ansichtsdatei habe ich es importiert und v-model wie folgt darin verwendet.

<!--MainPage.vue-->
<template>
...
...
     <CommentSection v-model="comment"/>
     <button @click="submitPost()"> Submit </button>
...
...
...
</template>
<script>
import CommentSection from '@/components/CommentSection.vue'

export default{
 name: 'MainPage',
      data(){
          return{
            comment: '',
          }
      },
      components: { CommentSection },
      methods:{
          submitPost(){
             console.log(this.comment);
          },
      },
}
</script>

Aber wenn ich die Konsole überprüfe, wird mir der Wert „null“ oder nichts angezeigt. Gibt es eine Möglichkeit, dieses Problem zu lösen? Oder vielleicht ist die Art und Weise, wie ich es implementiert habe, die Ursache des Problems.

EDIT: Hier ist der Code, der in codesandbox ausgeführt wird.

P粉550823577P粉550823577367 Tage vor539

Antworte allen(1)Ich werde antworten

  • P粉295728625

    P粉2957286252024-01-08 00:12:08

    我解决了你的问题,代码如下。希望对您有所帮助

    通过在div标签中添加@,我们可以在change方法中看到标签内容的变化。在该方法中,使用emit$与其他组件共享其值

    <!-- CommentSection.vue -->
    <template>
        <div id="chatId" @input="chanage" contenteditable="true" placeholder="Leave a message" class="overflow-hidden block mx-4 text-left p-2.5 w-full text-sm text-gray-900 bg-white rounded-2xl border border-gray-300 focus:ring-blue-500 focus:border-blue-500"/>
    </template>
    
    <script>
    export default {
      methods: {
        chanage (e) {
          this.$emit('value-div', e.target.textContent)
        }
      }
    }
    </script>
    
    <style>
    #chatId[contenteditable="true"]:empty:not(:focus):before {
        content: attr(placeholder)
    }
    </style>

    这里我们有 $emit 创建的 props,我们在 comment 变量中初始化它的值。其实它有类似v-model的功能。

    <!--MainPage.vue-->
    <template>
    ...
    ...
         <CommentSection @value-div="(value)=>comment = value"/>
         <button @click="submitPost()"> Submit </button>
    ...
    ...
    ...
    </template>
    <script>
    import CommentSection from '@/components/CommentSection.vue'
    
    export default{
     name: 'MainPage',
          data(){
              return{
                comment: '',
              }
          },
          components: { CommentSection },
          methods:{
              submitPost(){
                 console.log(this.comment);
              },
          },
    }
    </script>

    Antwort
    0
  • StornierenAntwort