Friday, January 3, 2025
Google search engine
HomeLanguagesJavascriptVue.js Form Input Binding with Multiline text

Vue.js Form Input Binding with Multiline text

Vue.js is a progressive javascript framework for developing web user interfaces. It is a versatile framework providing high speed and performance.  We can create Single Page Applications as well as Full Stack applications.

Input Binding is used to sync and maintain the state of form input elements with the corresponding state in javascript. So, Vue.js provides a v-model directive which makes the task of maintaining the state of the forms easier by the simple implementation.

Input Binding with multiline text uses the value property and input event for the v-model directive. It ignores the initial value on the form and updates whenever the user changes the form values.

Syntax:

Add the v-model directive to the textarea element for multiline text as follows:

<p style="white-space: pre-line;">
    {{message}}
</p>
<textarea v-model="message" placeholder="Details"></textarea>

Example: In the following example, we have a multiline text message box to write the text with the v-model directive. The message that we will write in the textarea element will be displayed in the paragraph element, simultaneously

Step 1: Create a new Vue.js project using the npm node.js package manager.

npm init vue@latest

Enter the project name and preset the project as follows:

 

Project Structure: After successful installation, the following project structure will be formed.

Project Structure

Step 2: Inside the App.vue file, add the data member message which will be used for the v-model in the data section of the script file. The v-model uses a data member to bind the data and it is very simple to implement.

App.vue




<script>
export default {
  data() {
    return {
      message: '',
    }
  },
}
</script>


Step 3: Now, in the template section, add the textarea element with a paragraph element to display the message that is being written. Inside the textarea, mention the v-model where we will specify the data member we defined earlier.

App.vue




<template>
  <center>
    <h1 style="text-align: center; color: green">neveropen</h1>
    <strong>
        Vue.js Form Input Value Binding with Multiline Text
    </strong>
    <br />
  </center>
  <center>
    <p style="white-space: pre-line">
      Multiline text message
      <br />
      {{ message }}
    </p>
  
    <textarea v-model="message" placeholder="Details"></textarea>
  </center>
</template>


Step 4: Run the project using the following command and see the output.

npm run dev

It will run the project on http://localhost:3000/ and the result will be as follows.

Output:

 

Reference: https://vuejs.org/guide/essentials/forms.html#multiline-text

Whether you’re preparing for your first job interview or aiming to upskill in this ever-evolving tech landscape, neveropen Courses are your key to success. We provide top-quality content at affordable prices, all geared towards accelerating your growth in a time-bound manner. Join the millions we’ve already empowered, and we’re here to do the same for you. Don’t miss out – check it out now!

RELATED ARTICLES

Most Popular

Recent Comments