목차
1. Prop을 사용하여 데이터 전달
二、camelCase vs.kebab-case
三、动态Prop
四、字面量语法vs动态语法
五、单项数据流
1.prop作为初始值传入,子组件之后只是将它的初始值作为本地数据的初始值使用;
2.prop作为需要被转变的原始值传入。
六、Prop验证
1.prop가 전달됩니다. 하위 구성 요소는 초기 값으로 초기 값을 로컬 데이터의 초기 값으로 사용합니다.
2. prop은 변환해야 하는 원래 값으로 전달됩니다.
6. Prop 검증🎜🎜구성요소는 prop에 대한 검증 요구 사항을 지정할 수 있습니다. Vue는 유효성 검사 요구 사항이 지정되지 않은 경우 경고를 표시합니다. 이는 해당 구성 요소를 다른 사람이 사용할 수 있도록 할 때 유용합니다. 🎜 prop이 문자열 배열이 아닌 객체인 경우 유효성 검사 요구 사항이 포함됩니다. 🎜rrreee🎜type은 다음 기본 생성자가 될 수 있습니다. 🎜🎜* 문자열 🎜🎜* 숫자 🎜🎜* 부울 🎜🎜 * 함수 🎜🎜* 객체 🎜🎜* Array🎜🎜type은 사용자 정의 생성자일 수도 있습니다. instanceof를 사용하여 감지하세요. 개발 버전을 사용하는 경우 소품 유효성 검사에 실패하면 경고가 표시됩니다. 🎜🎜관련 추천: "🎜vue.js Tutorial🎜"🎜
웹 프론트엔드 View.js vuejs에서 prop은 무엇을 의미하나요?

vuejs에서 prop은 무엇을 의미하나요?

Sep 18, 2021 pm 06:27 PM
prop vuejs

vuejs에서 prop은 상위 구성 요소가 데이터를 전달하는 데 사용하는 사용자 정의 속성입니다. 하위 구성 요소는 props 옵션을 사용하여 "prop"를 명시적으로 선언해야 합니다. 문자열이 아닌 템플릿을 사용할 때 prop 이름 형식은 camelCase에서 kebab-case(대시로 구분)로 변환됩니다.

vuejs에서 prop은 무엇을 의미하나요?

이 튜토리얼의 운영 환경: Windows 7 시스템, vue 버전 2.9.6, DELL G3 컴퓨터.

1. Prop을 사용하여 데이터 전달

구성 요소 인스턴스의 범위는 격리됩니다. 즉, 상위 구성 요소의 데이터는 하위 구성 요소의 템플릿 내에서 직접 참조될 수 없고 참조되어서도 안 됩니다. 소품을 사용하여 하위 구성 요소에 데이터를 전달할 수 있습니다.
prop은 데이터를 전달하기 위해 상위 구성 요소에서 사용하는 사용자 정의 속성입니다. 하위 구성 요소는 props 옵션 props选项声明“prop”

Vue.component('child',{
    props:['message'],
    template:&#39;<span>{{ message }}</span>&#39;
})
로그인 후 복사

然后向它传入一个普通字符串:

<child message="hello!"></child>
로그인 후 복사

结果:

hello!
로그인 후 복사

二、camelCase vs.kebab-case

html不区分大小写。当使用非字符串模板时,prop的名字形式会从camelCase转为kebab-case(短横线隔开):

//camelCase
Vue.component(&#39;child&#39;,{
    props:[&#39;myMessage&#39;],
    template:&#39;<span>{{ message }}</span>&#39;
})
로그인 후 복사
//kebab-case
<child my-message="hello!"></child>
로그인 후 복사

再次说明,如果你是用字符串模板,不用在意这些限制。

三、动态Prop

类似于用v-bind绑定HTML特性到一个表达式,也可以用v-bind动态绑定props的值到父组件的数据中。每当父组件的数据变化时,该变化也会传导给子组件。

<div>
    <input v-model="parrentMsg">
    <br>
    <child v-bind:my-message="parrentMsg"></child>
</div>
로그인 후 복사

使用v-bind的缩写语法通常更简单:

<child :my-message="parrentMsg"></child>
로그인 후 복사

四、字面量语法vs动态语法

因为它是一个字面prop ,它的值以字符串 "1" 而不是以实际的数字传下去。如果想传递一个实际的 JavaScript 数字,需要使用 v-bind ,从而让它的值被当作 JavaScript 表达式计算:

五、单项数据流

prop是单项绑定的:当父组件的属性变化时,将传导给子组件,但是不会反过来。这是为了防止子组件无意修改了父组件的状态——这会让应用的数据流难以理解。同时,这也很好理解,父组件是子组件的高度抽象,表示子组件的共有部分,一个组件的数据改变并不会改变其抽象,然而其抽象的改变却代表着所有子组件的改变。
另外,每次组渐渐更新时,子组件的所有prop都会更新为最新值。这意味着你不应该在子组件内部改变prop。如果你这么做了,Vue会在控制台给出警告。
通常有两种改变prop的情况:

1.prop作为初始值传入,子组件之后只是将它的初始值作为本地数据的初始值使用;

2.prop作为需要被转变的原始值传入。

更确切地说这两种情况是:
a.定义一个局部data属性,并将prop的初始值作为局部数据的初始值。

props: [‘initialCounter’], 
 data: function () { 
 return { counter: this.initialCounter} 
 }
로그인 후 복사
    b.定义一个 computed 属性,此属性从 prop 的值计算得出。
   ```
    props: [&#39;size&#39;],
    computed: {
        normalizedSize: function () {
         return this.size.trim().toLowerCase()
     }
    }
로그인 후 복사

六、Prop验证

组件可以为 props 指定验证要求。如果未指定验证要求,Vue 会发出警告。当组件给其他人使用时这很有用。
prop 是一个对象而不是字符串数组时,它包含验证要求:

Vue.component(&#39;example&#39;, {
  props: {
    // 基础类型检测 (`null` 意思是任何类型都可以)
    propA: Number,
    // 多种类型
    propB: [String, Number],
    // 必传且是字符串
    propC: {
      type: String,
      required: true
    },
    // 数字,有默认值
    propD: {
      type: Number,
      default: 100
    },
    // 数组/对象的默认值应当由一个工厂函数返回
    propE: {
      type: Object,
      default: function () {
        return { message: &#39;hello&#39; }
      }
    },
    // 自定义验证函数
    propF: {
      validator: function (value) {
        return value > 10
      }
    }
  }
})
로그인 후 복사

type可以是下面的原生构造器: 

* String 

* Number 

* Boolean 

* Function 

* Object 

* Array

type也可以是一个自定义构造器,使用instanceofrrreee

을 사용하여 "prop"를 명시적으로 선언한 다음 일반 문자열:

rrreee결과: rrreee

2. camelCase vs.kebab-case🎜🎜🎜html은 대소문자를 구분하지 않습니다. 문자열이 아닌 템플릿을 사용하는 경우 소품 이름 형식은 camelCase에서 kebab-case로 변환됩니다(대시로 구분). 🎜rrreeerrreee🎜다시 말하지만, 문자열 템플릿을 사용하는 경우 이러한 제한 사항에 대해 걱정하지 마세요. 🎜

🎜3개, 동적 Prop🎜🎜🎜v-bind를 사용하여 HTML 기능을 표현식에 바인딩하는 것과 유사하게 v-bind를 사용할 수도 있습니다. props 값을 상위 구성 요소의 데이터에 동적으로 바인딩합니다. 상위 구성 요소의 데이터가 변경될 때마다 변경 내용이 하위 구성 요소에도 전파됩니다. 🎜rrreee🎜약식 v-bind 구문을 사용하는 것이 일반적으로 더 간단합니다. 🎜rrreee

🎜4 리터럴 구문 vs 동적 구문🎜🎜🎜왜냐하면 값이 실제 숫자가 아닌 문자열 "1"로 전달되는 리터럴 prop입니다. 실제 JavaScript 숫자를 전달하려면 해당 값이 JavaScript 표현식으로 평가되도록 v-bind를 사용해야 합니다. 🎜🎜

🎜五, 단일 항목 데이터 흐름🎜🎜🎜prop은 단일 항목 바인딩입니다. 상위 구성 요소의 속성이 변경되면 하위 구성 요소로 전송되지만 그 반대는 아닙니다. 이는 하위 구성 요소가 상위 구성 요소의 상태를 실수로 수정하여 애플리케이션의 데이터 흐름을 이해하기 어렵게 만드는 것을 방지하기 위한 것입니다. 동시에, 이는 이해하기 쉽습니다. 상위 구성 요소는 하위 구성 요소의 공통 부분을 나타내는 상위 수준 추상화입니다. 구성 요소의 데이터가 변경되더라도 추상화는 변경되지 않습니다. 그러나 추상화의 변경은 모든 하위 구성 요소의 변경을 나타냅니다. 🎜 또한 그룹이 점진적으로 업데이트될 때마다 하위 구성 요소의 모든 소품이 최신 값으로 업데이트됩니다. 즉, 하위 구성 요소 내부의 소품을 변경하면 안 됩니다. 이렇게 하면 Vue가 콘솔에 경고를 표시합니다. 🎜 일반적으로 prop을 변경하는 경우는 두 가지입니다. 🎜

1.prop가 전달됩니다. 하위 구성 요소는 초기 값으로 초기 값을 로컬 데이터의 초기 값으로 사용합니다.

2. prop은 변환해야 하는 원래 값으로 전달됩니다.

🎜보다 정확하게는 다음 두 가지 상황입니다. 🎜 a. 로컬 데이터 속성을 정의하고 prop의 초기 값을 로컬 데이터의 초기 값으로 사용합니다. 🎜🎜rrreeerrreee

6. Prop 검증🎜🎜구성요소는 prop에 대한 검증 요구 사항을 지정할 수 있습니다. Vue는 유효성 검사 요구 사항이 지정되지 않은 경우 경고를 표시합니다. 이는 해당 구성 요소를 다른 사람이 사용할 수 있도록 할 때 유용합니다. 🎜 prop이 문자열 배열이 아닌 객체인 경우 유효성 검사 요구 사항이 포함됩니다. 🎜rrreee🎜type은 다음 기본 생성자가 될 수 있습니다. 🎜🎜* 문자열 🎜🎜* 숫자 🎜🎜* 부울 🎜🎜 * 함수 🎜🎜* 객체 🎜🎜* Array🎜🎜type은 사용자 정의 생성자일 수도 있습니다. instanceof를 사용하여 감지하세요. 개발 버전을 사용하는 경우 소품 유효성 검사에 실패하면 경고가 표시됩니다. 🎜🎜관련 추천: "🎜vue.js Tutorial🎜"🎜

위 내용은 vuejs에서 prop은 무엇을 의미하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Vue.js 및 Kotlin 언어를 사용하여 Android 애플리케이션을 개발하기 위한 몇 가지 팁 Vue.js 및 Kotlin 언어를 사용하여 Android 애플리케이션을 개발하기 위한 몇 가지 팁 Jul 31, 2023 pm 02:17 PM

Vue.js 및 Kotlin 언어를 사용하여 Android 애플리케이션을 개발하기 위한 몇 가지 팁 모바일 애플리케이션의 인기와 사용자 요구의 지속적인 증가로 인해 Android 애플리케이션 개발은 개발자들로부터 점점 더 많은 관심을 끌고 있습니다. Android 앱을 개발할 때 올바른 기술 스택을 선택하는 것이 중요합니다. 최근 몇 년 동안 Vue.js와 Kotlin 언어는 점차 Android 애플리케이션 개발에 널리 사용되는 언어가 되었습니다. 이 기사에서는 Vue.js 및 Kotlin 언어를 사용하여 Android 애플리케이션을 개발하는 몇 가지 기술을 소개하고 해당 코드 예제를 제공합니다. 1. 초기에 개발 환경을 설정한다

'[Vue 경고]: 필수 속성 누락' 오류 해결 방법 '[Vue 경고]: 필수 속성 누락' 오류 해결 방법 Aug 26, 2023 pm 06:57 PM

"[Vuewarn]:Missingrequiredprop" 오류를 해결하는 방법 Vue 애플리케이션을 개발할 때 "[Vuewarn]:Missingrequiredprop"라는 일반적인 오류 메시지가 나타나는 경우가 있습니다. 이 오류는 일반적으로 구성 요소에 필수 속성 값이 부족하여 구성 요소가 제대로 렌더링되지 않음을 나타냅니다. 이 문제에 대한 해결책은 간단합니다. 몇 가지 기술과 규정을 통해 이 오류를 방지하고 처리할 수 있습니다. 다음은 몇 가지 해결 방법입니다.

Vue.js 및 Python을 사용하여 데이터 시각화 애플리케이션을 개발하기 위한 몇 가지 팁 Vue.js 및 Python을 사용하여 데이터 시각화 애플리케이션을 개발하기 위한 몇 가지 팁 Jul 31, 2023 pm 07:53 PM

Vue.js 및 Python을 사용하여 데이터 시각화 애플리케이션을 개발하기 위한 몇 가지 팁 소개: 빅 데이터 시대의 도래와 함께 데이터 시각화는 중요한 솔루션이 되었습니다. 데이터 시각화 애플리케이션 개발에서 Vue.js와 Python의 조합은 유연성과 강력한 기능을 제공할 수 있습니다. 이 기사에서는 Vue.js 및 Python을 사용하여 데이터 시각화 애플리케이션을 개발하기 위한 몇 가지 팁을 공유하고 해당 코드 예제를 첨부합니다. 1. Vue.js 소개 Vue.js는 경량 JavaScript입니다.

Vue.js 및 Lua 언어 통합, 게임 개발을 위한 프런트엔드 엔진 구축 시 모범 사례 및 경험 공유 Vue.js 및 Lua 언어 통합, 게임 개발을 위한 프런트엔드 엔진 구축 시 모범 사례 및 경험 공유 Aug 01, 2023 pm 08:14 PM

Vue.js와 Lua 언어의 통합, 게임 개발을 위한 프런트엔드 엔진 구축을 위한 모범 사례 및 경험 공유 소개: 게임 개발이 지속적으로 발전함에 따라 게임 프런트엔드 엔진의 선택이 중요한 결정이 되었습니다. 이러한 선택 중에서 Vue.js 프레임워크와 Lua 언어는 많은 개발자의 초점이 되었습니다. 널리 사용되는 프런트엔드 프레임워크인 Vue.js는 풍부한 생태계와 편리한 개발 방법을 갖추고 있으며, Lua 언어는 가볍고 효율적인 성능으로 인해 게임 개발에 널리 사용됩니다. 이 기사에서는 다음 방법을 살펴보겠습니다.

PHP 및 Vue.js를 사용하여 차트에서 데이터 필터링 및 정렬 기능을 구현하는 방법 PHP 및 Vue.js를 사용하여 차트에서 데이터 필터링 및 정렬 기능을 구현하는 방법 Aug 27, 2023 am 11:51 AM

PHP 및 Vue.js를 사용하여 차트에서 데이터 필터링 및 정렬 기능을 구현하는 방법 웹 개발에서 차트는 데이터를 표시하는 매우 일반적인 방법입니다. 차트의 데이터 필터링 및 정렬 기능은 PHP 및 Vue.js를 사용하여 쉽게 구현할 수 있으므로 사용자는 차트의 데이터 보기를 사용자 정의하고 데이터 시각화 및 사용자 경험을 향상시킬 수 있습니다. 먼저 차트에서 사용할 데이터 세트를 준비해야 합니다. 이름, 나이, 학년이라는 세 개의 열을 포함하는 데이터 테이블이 있다고 가정합니다. 데이터는 이름, 나이, 학년 Zhang San 1890 Li입니다.

멋진 모바일 애플리케이션 UI 인터페이스를 구축하기 위한 Vue.js 및 Dart 언어, 실무 및 개발 기술 통합 멋진 모바일 애플리케이션 UI 인터페이스를 구축하기 위한 Vue.js 및 Dart 언어, 실무 및 개발 기술 통합 Aug 02, 2023 pm 03:33 PM

Vue.js와 Dart 언어의 통합, 멋진 모바일 애플리케이션 UI 인터페이스 구축을 위한 실습 및 개발 기술 소개: 모바일 애플리케이션 개발에서 사용자 인터페이스(UI)의 디자인과 구현은 매우 중요한 부분입니다. 멋진 모바일 애플리케이션 인터페이스를 달성하기 위해 Vue.js를 Dart 언어와 통합하고 Vue.js의 강력한 데이터 바인딩 및 구성 요소화 기능과 Dart 언어의 풍부한 모바일 애플리케이션 개발 라이브러리를 사용하여 멋진 모바일 애플리케이션을 구축할 수 있습니다. UI 인터페이스. 이 기사에서는 다음 방법을 보여줍니다.

Vue.js 및 Perl 언어를 사용하여 효율적인 웹 크롤러 및 데이터 스크래핑 도구 개발 Vue.js 및 Perl 언어를 사용하여 효율적인 웹 크롤러 및 데이터 스크래핑 도구 개발 Jul 31, 2023 pm 06:43 PM

Vue.js 및 Perl 언어를 사용하여 효율적인 웹 크롤러 및 데이터 스크래핑 도구를 개발하십시오. 최근 인터넷의 급속한 발전과 데이터의 중요성이 증가함에 따라 웹 크롤러 및 데이터 스크래핑 도구에 대한 수요도 증가했습니다. 이러한 맥락에서 Vue.js와 Perl 언어를 결합하여 효율적인 웹 크롤러와 데이터 스크래핑 도구를 개발하는 것은 좋은 선택입니다. 이 기사에서는 Vue.js 및 Perl 언어를 사용하여 이러한 도구를 개발하는 방법을 소개하고 해당 코드 예제를 첨부합니다. 1. Vue.js 및 Perl 언어 소개

Vue를 사용하여 QQ와 유사한 채팅 풍선 효과를 구현하는 방법 Vue를 사용하여 QQ와 유사한 채팅 풍선 효과를 구현하는 방법 Sep 20, 2023 pm 02:27 PM

Vue를 사용하여 QQ와 같은 채팅 버블 효과를 구현하는 방법 오늘날 소셜 시대에 채팅 기능은 모바일 애플리케이션과 웹 애플리케이션의 핵심 기능 중 하나가 되었습니다. 채팅 인터페이스의 가장 일반적인 요소 중 하나는 채팅 풍선입니다. 이는 발신자와 수신자의 메시지를 명확하게 구분하여 메시지의 가독성을 효과적으로 향상시킬 수 있습니다. 이 글에서는 Vue를 사용하여 QQ와 유사한 채팅 풍선 효과를 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 먼저 채팅 풍선을 나타내는 Vue 구성 요소를 만들어야 합니다. 구성 요소는 두 가지 주요 부분으로 구성됩니다.

See all articles