vue+props를 사용하여 데이터 전송을 구현하는 방법
이번에는 vue+props를 구현하여 데이터를 전송하는 방법과 vue+props를 사용하여 데이터를 전송할 때 주의사항이 무엇인지 보여드리겠습니다. 다음은 실제 사례입니다.
Vue에서 부모와 자식 구성 요소 간의 관계는 소품이 아래로 전달되고 이벤트가 위로 전달되는 것으로 요약할 수 있습니다. 부모 컴포넌트는 props를 통해 자식 컴포넌트에 데이터를 보내고, 자식 컴포넌트는 이벤트를 통해 부모 컴포넌트에 메시지를 보냅니다. 작동 방식을 확인하세요.
1. 기본 사용법
구성 요소는 템플릿의 콘텐츠를 재사용해야 할 뿐만 아니라 더 중요한 것은 구성 요소 간 통신이 필요하다는 것입니다.
컴포넌트에서 props 옵션을 사용하여 부모로부터 받아야 하는 데이터를 선언합니다. props의 값은 두 가지 유형이 될 수 있습니다. 하나는 문자열 배열이고 다른 하나는 객체입니다.
1.1 문자열 배열:
<p id="app4"> <my-component4 message="数据来自父组件"></my-component4> </p> Vue.component('my-component4',{ props: ['message'], template: '<p>{{message}}</p>' }); var app4 = new Vue({ el: '#app4' });
렌더링된 결과는 다음과 같습니다.
<p id= ” app4”> <p >来自父组件的数据</ p> </p>
props에 선언된 데이터와 구성 요소 데이터 함수에 의해 반환된 데이터의 주요 차이점은 props가 상위 항목에서 온 반면, props의 데이터는 상위 항목에서 온다는 것입니다. 데이터는 구성 요소 자체입니다. 데이터 범위는 구성 요소 자체입니다. 두 데이터 모두 템플릿, 계산된 속성 및 메서드에서 사용할 수 있습니다.
위 예제의 데이터 메시지는 props를 통해 부모로부터 전달됩니다. 여러 데이터를 전달하려면 props 배열에 항목을 추가하기만 하면 됩니다.
때로는 전달되는 데이터가 직접 하드코딩되지 않고 상위 컴포넌트의 동적 데이터인 경우 이 경우 상위 컴포넌트의 데이터가 변경되면 v -bind 명령을 사용하여 동적으로 바인딩할 수 있습니다. 또한 하위 구성 요소에도 전달됩니다.
<p id="app5"> <input type="text" v-model="text"> <my-component5 :my-text="text"></my-component5> </p> Vue.component('my-component5',{ props: ['myText'], template: '<p>{{myText}}</p>' }); var app5 = new Vue({ el: '#app5', data: { text: '动态传递父组件数据' } });
몇 가지 참고 사항:
1. 숫자, 부울 값, 배열, 객체를 직접 전달하고 v-bind를 사용하지 않는 경우 문자열만 전달됩니다.
2. 객체의 모든 속성을 props로 전달하려면 매개변수 없이 v-bind를 사용하면 됩니다(즉, v-bind:prop-name 대신 v-bind를 사용하세요). 예를 들어 알려진 todo 객체:
1.2 객체:
prop를 확인해야 할 경우 객체 작성이 필요합니다.
일반적으로 다른 사람이 사용할 수 있도록 구성 요소를 제공해야 하는 경우 데이터 검증을 수행하는 것이 좋습니다. 예를 들어 특정 데이터는 숫자 형식이어야 합니다. 콘솔.
<p id="app6"> <input type="text" v-model="number"> <my-component6 :my-text="number"></my-component6> </p> Vue.component('my-component6',{ props: { 'myText':{ type: Number, //必须是数字类型的 required: true, //必须传值 default: 1 //如果未定义,默认值就是1 } }, template: '<p>{{myText}}</p>' }); var app6 = new Vue({ el: '#app6', data: { number: 1 } });
확인된 유형은 다음과 같습니다.
• 문자열
• 숫자
• 부울
• 객체
• 배열
• 함수
유형은 감지 인스턴스를 사용하여 사용자 정의 생성자가 될 수도 있습니다.
prop 확인에 실패하면 개발 버전의 콘솔에 경고가 표시됩니다.
2. 단방향 데이터 흐름
Vue 2.x와 Vue l.x의 더 큰 변화는 Vue2.x가 props를 통해 한 방향으로 데이터를 전송한다는 것, 즉 상위 컴포넌트 데이터가 변경되면 하위 구성 요소로 전송되지만 그 반대는 아닙니다.
비즈니스에서는 prop을 변경해야 하는 두 가지 상황이 자주 발생합니다.
2.1: 하나는 상위 구성 요소가 초기 값을 전달하고 하위 구성 요소는 이를 사용 및 수정할 수 있는 초기 값으로 저장하는 것입니다. 자체 범위 내에서 마음대로. (Prop이 초기값으로 전달된 후 하위 컴포넌트는 이를 로컬 데이터로 사용하려고 합니다.)
이 경우 컴포넌트 데이터에 다른 데이터를 선언하고 상위 컴포넌트의 prop을 참조할 수 있습니다. 코드는 다음과 같습니다.
<p id="app7"> <my-component7 :init-count="1"></my-component7> </p> Vue.component('my-component7',{ props: ['initCount'], template: '<p>{{count}}</p>', data: function(){ return { count: this.initCount } } }); var app7 = new Vue({ el: '#app7' });
데이터 개수는 구성 요소가 초기화될 때 상위 구성 요소에서 가져옵니다. 이후에는 개수와 관련이 없으므로 개수만 유지합니다. initCount를 직접 조작하는 것을 피할 수 있습니다.
2.2 prop는 변환해야 하는 원래 값으로 전달됩니다. (Prop은 원시 데이터로 전달되고 하위 구성 요소에 의해 다른 데이터 출력으로 처리됩니다.)
이 경우 계산된 속성으로 충분합니다. 샘플 코드는 다음과 같습니다.
<p id="app8"> <my-component8 :width="100"></my-component8> </p> Vue.component('my-component8',{ props: ['width'], template: '<p :style="style">组件内容</p>', computed: { style: function(){ return { width: this.width+'px' } } } }); var app8 = new Vue({ el: '#app8' });
JavaScript에서는 객체와 배열이 참조 유형과 동일한 메모리 공간을 가리킵니다. prop이 객체나 배열인 경우 하위 구성 요소 내에서 이를 변경하면 상위 구성 요소의 상태에 영향을 미칩니다.
이 기사의 사례를 읽으신 후 방법을 마스터하셨다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!
추천 도서:
체크 및 계단식 선택이 포함된 트리 메뉴 사용에 대한 자세한 설명
위 내용은 vue+props를 사용하여 데이터 전송을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











vue.js에서 bootstrap 사용은 5 단계로 나뉩니다 : Bootstrap 설치. main.js.의 부트 스트랩 가져 오기 부트 스트랩 구성 요소를 템플릿에서 직접 사용하십시오. 선택 사항 : 사용자 정의 스타일. 선택 사항 : 플러그인을 사용하십시오.

HTML 템플릿의 버튼을 메소드에 바인딩하여 VUE 버튼에 함수를 추가 할 수 있습니다. 메소드를 정의하고 VUE 인스턴스에서 기능 로직을 작성하십시오.

vue.js의 시계 옵션을 사용하면 개발자가 특정 데이터의 변경 사항을들을 수 있습니다. 데이터가 변경되면 콜백 기능을 트리거하여 업데이트보기 또는 기타 작업을 수행합니다. 구성 옵션에는 즉시 콜백을 실행할지 여부와 DEEP를 지정하는 즉시 포함되며, 이는 객체 또는 어레이에 대한 변경 사항을 재귀 적으로 듣는 지 여부를 지정합니다.

VUE 멀티 페이지 개발은 vue.js 프레임 워크를 사용하여 응용 프로그램을 구축하는 방법입니다. 여기서 응용 프로그램은 별도의 페이지로 나뉩니다. 코드 유지 보수 : 응용 프로그램을 여러 페이지로 분할하면 코드를보다 쉽게 관리하고 유지 관리 할 수 있습니다. 모듈 식 : 각 페이지는 쉬운 재사용 및 교체를 위해 별도의 모듈로 사용할 수 있습니다. 간단한 라우팅 : 페이지 간의 탐색은 간단한 라우팅 구성을 통해 관리 할 수 있습니다. SEO 최적화 : 각 페이지에는 자체 URL이있어 SEO가 도움이됩니다.

vue.js에서 JS 파일을 참조하는 세 가지 방법이 있습니다. & lt; script & gt; 꼬리표;; mounted () 라이프 사이클 후크를 사용한 동적 가져 오기; Vuex State Management Library를 통해 수입.

vue.js는 이전 페이지로 돌아갈 수있는 네 가지 방법이 있습니다. $ router.go (-1) $ router.back () 사용 & lt; router-link to = & quot;/quot; Component Window.history.back () 및 메소드 선택은 장면에 따라 다릅니다.

vue.js가 트래버스 어레이 및 객체에 대한 세 가지 일반적인 방법이 있습니다. V- 결합 지시문은 V-FOR와 함께 사용하여 각 요소의 속성 값을 동적으로 설정할 수 있습니다. .MAP 메소드는 배열 요소를 새 배열로 변환 할 수 있습니다.

VUE에서 DIV 요소를 점프하는 두 가지 방법이 있습니다. VUE 라우터를 사용하고 라우터 링크 구성 요소를 추가하십시오. @Click 이벤트 리스너를 추가하고 이것을 호출하십시오. $ router.push () 메소드를 점프하십시오.
