Table of Contents
Passing prop attributes
Receive prop attributes
Default value
Home Web Front-end Vue.js How Vue components pass and receive prop properties

How Vue components pass and receive prop properties

Oct 15, 2023 am 09:46 AM
vue component prop

How Vue components pass and receive prop properties

How Vue components pass and receive prop attributes requires specific code examples

Vue is a popular JavaScript framework that is widely used in front-end development. In Vue, components are the basic units for building applications. Components can pass properties (props) and receive properties (props), allowing data interaction between components. This article will introduce in detail how Vue components pass and receive prop attributes, and provide specific code examples.

Passing prop attributes

In Vue, you can pass prop attributes by using the v-bind directive on the component tag. The v-bind directive is used to dynamically bind one or more properties to an expression. The following is an example that demonstrates how to pass a string type prop attribute:

<template>
  <div>
    <child-component :message="parentMessage"></child-component>
  </div>
</template>

<script>
import ChildComponent from "./ChildComponent.vue";

export default {
  data() {
    return {
      parentMessage: "Hello from parent"
    };
  },
  components: {
    ChildComponent
  }
};
</script>
Copy after login

In the above code, the parent component passes a prop attribute named message to the child component, And bound to the parentMessage data in the parent component.

In child components, you can receive passed prop properties by declaring the property in the props option. The following is a code example for a subcomponent:

<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>

<script>
export default {
  props: {
    message: {
      type: String,
      required: true
    }
  }
};
</script>
Copy after login
Copy after login

In the above code, a property named message is declared in the props option and its type is specified is a string. required: trueIndicates that this attribute is required. If the parent component does not pass this attribute, a warning will be output on the console.

Receive prop attributes

Once a prop attribute is declared in a child component, it can be used in the child component's template. The following is an example that shows how to receive and use prop attributes in a child component:

<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>

<script>
export default {
  props: {
    message: {
      type: String,
      required: true
    }
  }
};
</script>
Copy after login
Copy after login

In the above code, {{ message }} is used to display in the template of the child component The passed prop attribute. The child component will display Hello from parent.

It should be noted that once the prop attribute is declared and used in a child component, it will be considered a read-only property. If you try to modify the value of the prop attribute inside a child component, Vue will output a warning to the console.

Default value

You can set a default value for the prop attribute. When the parent component does not pass this attribute, the default value will be used. The following is an example:

<template>
  <div>
    <child-component></child-component>
  </div>
</template>

<script>
import ChildComponent from "./ChildComponent.vue";

export default {
  components: {
    ChildComponent
  }
};
</script>
Copy after login

In child components, you can set the default value through the default option:

<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>

<script>
export default {
  props: {
    message: {
      type: String,
      default: "Default message"
    }
  }
};
</script>
Copy after login

In the above code, if the parent component does not pass message attribute, the child component will display Default message.

Summary:

This article introduces how Vue components pass and receive prop attributes, and provides specific code examples. In Vue, prop properties can be passed to child components by using the v-bind directive, and the child component can receive them by declaring and using these properties in the props option. Additionally, you can set default values ​​for prop properties. Mastering this knowledge allows developers to perform component development more effectively and realize data interaction between components.

The above is the detailed content of How Vue components pass and receive prop properties. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Is Vue used for frontend or backend? Is Vue used for frontend or backend? Apr 03, 2025 am 12:07 AM

Vue.js is mainly used for front-end development. 1) It is a lightweight and flexible JavaScript framework focused on building user interfaces and single-page applications. 2) The core of Vue.js is its responsive data system, and the view is automatically updated when the data changes. 3) It supports component development, and the UI can be split into independent and reusable components.

How do I create and use custom plugins in Vue.js? How do I create and use custom plugins in Vue.js? Mar 14, 2025 pm 07:07 PM

Article discusses creating and using custom Vue.js plugins, including development, integration, and maintenance best practices.

How do I use tree shaking in Vue.js to remove unused code? How do I use tree shaking in Vue.js to remove unused code? Mar 18, 2025 pm 12:45 PM

The article discusses using tree shaking in Vue.js to remove unused code, detailing setup with ES6 modules, Webpack configuration, and best practices for effective implementation.Character count: 159

Is vue.js hard to learn? Is vue.js hard to learn? Apr 04, 2025 am 12:02 AM

Vue.js is not difficult to learn, especially for developers with a JavaScript foundation. 1) Its progressive design and responsive system simplify the development process. 2) Component-based development makes code management more efficient. 3) The usage examples show basic and advanced usage. 4) Common errors can be debugged through VueDevtools. 5) Performance optimization and best practices, such as using v-if/v-show and key attributes, can improve application efficiency.

What are the key features of Vue.js (Component-Based Architecture, Virtual DOM, Reactive Data Binding)? What are the key features of Vue.js (Component-Based Architecture, Virtual DOM, Reactive Data Binding)? Mar 14, 2025 pm 07:05 PM

Vue.js enhances web development with its Component-Based Architecture, Virtual DOM for performance, and Reactive Data Binding for real-time UI updates.

What is the method of converting Vue.js strings into objects? What is the method of converting Vue.js strings into objects? Apr 07, 2025 pm 09:18 PM

Using JSON.parse() string to object is the safest and most efficient: make sure that strings comply with JSON specifications and avoid common errors. Use try...catch to handle exceptions to improve code robustness. Avoid using the eval() method, which has security risks. For huge JSON strings, chunked parsing or asynchronous parsing can be considered for optimizing performance.

How do I configure Vue CLI to use different build targets (development, production)? How do I configure Vue CLI to use different build targets (development, production)? Mar 18, 2025 pm 12:34 PM

The article explains how to configure Vue CLI for different build targets, switch environments, optimize production builds, and ensure source maps in development for debugging.

How do I use Vue with Docker for containerized deployment? How do I use Vue with Docker for containerized deployment? Mar 14, 2025 pm 07:00 PM

The article discusses using Vue with Docker for deployment, focusing on setup, optimization, management, and performance monitoring of Vue applications in containers.

See all articles