vuejs prop 사용법: 1. Prop을 사용하여 "<child message="hello!"></child>"와 같은 문으로 데이터를 전달합니다. 2. v-bind를 사용하여 값을 동적으로 바인딩합니다. 상위 구성 요소 데이터 등에 대한 소품입니다.
이 기사의 운영 환경: Windows 7 시스템, vue 버전 2.9.6, DELL G3 컴퓨터.
Vuejs Prop의 기본 사용법
1. Prop을 사용하여 데이터 전송
구성 요소 인스턴스의 범위는 격리됩니다. 즉, 상위 구성 요소의 데이터는 하위 구성 요소의 템플릿 내에서 직접 참조될 수 없고 참조되어서도 안 됩니다. 소품을 사용하여 하위 구성 요소에 데이터를 전달할 수 있습니다.
prop는 데이터를 전달하기 위해 상위 구성 요소에서 사용하는 사용자 정의 속성입니다. 하위 구성 요소는 props 옵션
Vue.component('child',{ props:['message'], template:'<span>{{ message }}</span>' })
을 사용하여 "prop"를 명시적으로 선언한 다음 일반 문자열을 전달해야 합니다.
<child message="hello!"></child>
결과:
hello!
2. camelCase vs.kebab-case
html은 대소문자를 구분하지 않습니다. 문자열이 아닌 템플릿을 사용하는 경우 prop 이름 형식은 camelCase에서 kebab-case(대시 구분)로 변환됩니다.
//camelCase Vue.component('child',{ props:['myMessage'], template:'<span>{{ message }}</span>' })
//kebab-case <child my-message="hello!"></child>
다시 말하지만, 문자열 템플릿을 사용하는 경우 이러한 제한 사항에 대해 걱정하지 마세요.
3. 동적 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>
4. 리터럴 구문과 동적 구문
리터럴 prop이므로 해당 값은 실제 숫자가 아닌 문자열 "1"로 전달됩니다. 내려가세요. 실제 JavaScript 숫자를 전달하려면 해당 값이 JavaScript 표현식으로 평가되도록 v-bind를 사용해야 합니다.
5. 단일 항목 데이터 흐름
prop는 단일 항목 바인딩입니다. 상위 구성 요소 변경은 하위 구성 요소로 전달되지만 그 반대는 아닙니다. 이는 하위 구성 요소가 상위 구성 요소의 상태를 실수로 수정하여 애플리케이션의 데이터 흐름을 이해하기 어렵게 만드는 것을 방지하기 위한 것입니다. 동시에, 이는 이해하기 쉽습니다. 상위 구성 요소는 하위 구성 요소의 공통 부분을 나타내는 상위 수준 추상화입니다. 구성 요소의 데이터가 변경되더라도 추상화는 변경되지 않습니다. 그러나 추상화의 변경은 모든 하위 구성 요소의 변경을 나타냅니다.
또한 그룹이 점진적으로 업데이트될 때마다 하위 구성 요소의 모든 소품이 최신 값으로 업데이트됩니다. 즉, 하위 구성 요소 내부의 소품을 변경하면 안 됩니다. 이렇게 하면 Vue가 콘솔에 경고를 표시합니다.
prop를 변경하는 경우는 일반적으로 두 가지입니다.
1.prop가 초기 값으로 전달되고 하위 구성 요소는 초기 값을 로컬 데이터의 초기 값으로 사용합니다.
2.prop는 원본으로 사용됩니다. 변환해야 하는 값 값이 전달됩니다.
보다 정확하게는 다음 두 가지 상황입니다.
a.定义一个局部data属性,并将prop的初始值作为局部数据的初始值。 “` props: [‘initialCounter’], data: function () { return { counter: this.initialCounter} } b.定义一个 computed 属性,此属性从 prop 的值计算得出。 ``` props: ['size'], computed: { normalizedSize: function () { return this.size.trim().toLowerCase() } }
6. Prop 검증
구성 요소는 Prop에 대한 검증 요구 사항을 지정할 수 있습니다. Vue는 유효성 검사 요구 사항이 지정되지 않은 경우 경고를 발행합니다. 이는 구성요소를 다른 사람이 사용할 수 있게 만들 때 유용합니다.
prop가 문자열 배열이 아닌 개체인 경우 유효성 검사 요구 사항이 포함됩니다.
Vue.component('example', { props: { // 基础类型检测 (`null` 意思是任何类型都可以) propA: Number, // 多种类型 propB: [String, Number], // 必传且是字符串 propC: { type: String, required: true }, // 数字,有默认值 propD: { type: Number, default: 100 }, // 数组/对象的默认值应当由一个工厂函数返回 propE: { type: Object, default: function () { return { message: 'hello' } } }, // 自定义验证函数 propF: { validator: function (value) { return value > 10 } } } })
type은 다음과 같은 기본 생성자가 될 수 있습니다.
* String
* Number
* Boolean
* Function
* 개체
* Array
type은 사용자 정의 생성자일 수도 있으며, instanceof를 사용하여 감지됩니다. 개발 버전을 사용하는 경우 소품 유효성 검사에 실패하면 경고가 표시됩니다.
추천: "5개의 vue.js 비디오 튜토리얼 중 최신 선택"
위 내용은 vuejs prop의 사용법은 무엇입니까의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!