Vue의 내장 구성 요소 구성 요소의 애플리케이션 시나리오에 대한 간략한 토론
이 글은 주로 Vue 내장 컴포넌트 컴포넌트의 적용 시나리오를 소개하고 참고용으로 제공합니다.
공식 지침
"메타 구성 요소"를 동적 구성 요소로 렌더링합니다. 렌더링되는 구성 요소는 is 값에 따라 다릅니다.
<!-- 动态组件由 vm 实例的属性值 `componentId` 控制 --> <component :is="componentId"></component>
자세한 내용은 공식 웹 사이트 문서에서
동적 구성 요소
내장 구성 요소 구성 요소
Scenario
를 참조하세요. 여기에서는 비즈니스 시나리오를 사용하여 Vue의 내장 애플리케이션을 설명합니다. -구성 요소 구성 요소. 그림과 같이 클래식 등록 페이지가 표시됩니다. 등록은 이메일 등록과 휴대폰 등록으로 구분됩니다. 팝업 창 상단에 등록 유형을 전환하는 라벨이 있습니다. 양식 정보입니다. 이메일 등록과 휴대폰 등록은 양식 내용이 다릅니다. 하단에는 등록 버튼과 기타 작업이 있습니다. 분석 결과, 휴대폰 등록 인터페이스와 이메일 등록 인터페이스는 중간 양식의 내용이 일치하지 않는 점을 제외하면 동일합니다.
실제 프로젝트 코드 설계에는 재사용성과 유지 관리성을 보장할 수 있는 몇 가지 실현 가능한 솔루션이 있습니다. 여기서는 이를 달성하기 위해 vue의 내장 구성 요소를 사용합니다.
핵심 코드 구현
상단 탭이 전환되면 타입 값이 변경되고, 해당 폼 컴포넌트도 변경됩니다
<template> <p> <a href="javascript:;" rel="external nofollow" rel="external nofollow" @click.prevent="handleCloseBtnClick"></a> <p> <h3>新用户注册</h3> <p> <span :class="{active: type === 'mobileForm'}" @click="type = mobileForm">手机注册</span> <span :class="{active: type === 'emailForm'}" @click="type = emailForm">邮箱注册</span> </p> </p> <component :is="type" ref="form"> <button @click="handleRegisterBtnClick">注册</button> <p ><span ><span>注册视为同意</span><a> 《法律条款和隐私说明》</a></span></p> <p><span>已有账号<a href="javascript:;" rel="external nofollow" rel="external nofollow" @click.prevent="handleLoginBtnClick">直接登入>></a></span></p> </component> </p> </template> <script> export default { methods: { handleRegisterBtnClick () { this.$refs.form.validateData().then(() => { this.$refs.form.getFormData() }) } } } </script>
mixins mixins
Vue 내장 컴포넌트 컴포넌트를 사용할 때, 일반적으로 실제로 렌더링되는 구성 요소에는 동일한 속성, 동일한 방법 또는 동일한 초기화 및 소멸 프로세스와 같은 특정 공통점이 있습니다. 예를 들어, 현재 시나리오에서는 이메일 양식과 휴대폰 양식 모두 확인 방법(validateData)과 양식 데이터를 가져오는 방법(getFormData)이 있습니다. 이 경우 vue에서 제공하는 하이브리드 기능을 사용할 수 있습니다. 추가 추상화 mixins.js
export default { methods: { validateData() { return Promise.resolve() }, getFormData() { return {} } } }
email-form.vue
<script> import minx from './mixins' export default { mixins: [mixins], methods: { getFormData() { return { email: 'example@example.com' } } } } </script>
맞춤형 요구 사항이 있는 경우 mixins의 메서드를 재정의할 수 있습니다.
테이블 적용
관리 백그라운드 프로젝트에서는 테이블을 자주 사용합니다. 테이블의 td가 텍스트, 진행률 표시줄, 체크박스 등이길 바라며, json 구성을 전달하여 렌더링할 수 있기를 바랍니다. Vue에 내장된 구성 요소를 사용하면 큰 역할을 할 수 있습니다.
예를 들어 이런 테이블 사용법
<template> <vue-table ref="table" :columns="columns" :datum="datum"></vue-table> </template> <script> export default { data () { return { columns: [ { title: 'ID', width: '30', dataKey: 'id' }, { title: '进度组件', dataKey: 'progress', render: { type: 'progress2', max: 100, precision: 2 } } ], datum: [{ id: '1', name: '进度0', progress: 10 }] } } } </script>
테이블에 컴포넌트 구현
<td v-for="column of columns"> <component :is="`${TYPE_PRE}${columns.render.type}`" :row-data="rowData" :params="columns.render"></component> </td>
폼 적용
관리 백그라운드 프로젝트에서는 폼이 자주 사용되는데 저희도 저 역시 양식의 항목 중 하나가 텍스트 상자, 드롭다운 상자, 시간 선택 상자, 서식 있는 텍스트 등이길 바라며, json 구성을 전달하여 렌더링할 수 있기를 바랍니다. Vue의 내장 컴포넌트는 여전히 아름다운 비전을 실현할 수 있습니다.
예를 들어 이런 양식을 사용하는 방법
<template> <c-form :cells="cells" ref="form"> <button class="button is-primary" :class="{ 'is-disabled': isSubmitBtnDisabled }" @click.prevent="submit">提交</button> </c-form> </template> <script> export default { computed: { cells () { return [ { field: 'name', label: '名称', type: 'textfield', attrs: { placeholder: '名称' }, validate: { required: { message: '请输入名称'} } }, { field: 'enable', label: '启用标志', type: 'dropdown', extra: {options: [{ label: '启用', value: 1 }, { label: '禁用', value: 2 }] } } ] } } } </script>
양식에서 컴포넌트를 사용하는 구현
<form> <c-form-cell v-for="cell of cellList" :key="cell.field" :field="cell.field"> <component :is="`${TYPE_PRE}${cell.type}`" :field="cell.field" :attrs="cell.attrs" :extra="cell.extra" :validate="cell.validate" :cells="cell.cells"> </component> </c-form-cell> </form>
위 내용은 제가 정리한 내용입니다. 앞으로 모든 분들께 도움이 되길 바랍니다. .
관련 기사:
jquery의 Ajax 동기화 및 비동기에 대한 자세한 설명
위 내용은 Vue의 내장 구성 요소 구성 요소의 애플리케이션 시나리오에 대한 간략한 토론의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











홈 화면에서 중요한 항목을 삭제하고 다시 복구하려고 하시나요? 다양한 방법으로 앱 아이콘을 화면에 다시 표시할 수 있습니다. 우리는 당신이 따라갈 수 있는 모든 방법과 홈 화면에 앱 아이콘을 다시 넣을 수 있는 방법에 대해 논의했습니다. 방법 1 - 앱 라이브러리에서 앱 아이콘 바꾸기 앱 라이브러리에서 직접 홈 화면에 앱 아이콘을 배치할 수 있습니다. 1단계 – 옆으로 스와이프하여 앱 라이브러리의 모든 앱을 찾습니다. 2단계 – 이전에 삭제한 앱 아이콘을 찾습니다. 3단계 – 메인 라이브러리의 앱 아이콘을 홈 화면의 올바른 위치로 드래그하기만 하면 됩니다. 이것은 응용 다이어그램입니다

PHP에서 화살표 기호의 역할과 실제 적용 PHP에서 화살표 기호(->)는 일반적으로 객체의 속성과 메서드에 액세스하는 데 사용됩니다. 객체는 PHP의 객체지향 프로그래밍(OOP)의 기본 개념 중 하나입니다. 실제 개발에서는 객체를 조작할 때 화살표 기호가 중요한 역할을 합니다. 이 기사에서는 화살표 기호의 역할과 실제 적용을 소개하고 독자의 이해를 돕기 위해 구체적인 코드 예제를 제공합니다. 1. 객체의 속성에 접근하기 위한 화살표 기호의 역할 화살표 기호를 사용하여 객체의 속성에 접근할 수 있습니다. 쌍을 인스턴스화할 때

Linuxtee 명령은 기존 출력에 영향을 주지 않고 출력을 파일에 쓰거나 출력을 다른 명령으로 보낼 수 있는 매우 유용한 명령줄 도구입니다. 이 기사에서는 초보자부터 숙련자까지 Linuxtee 명령의 다양한 애플리케이션 시나리오를 심층적으로 살펴보겠습니다. 1. 기본 사용법 먼저 tee 명령어의 기본 사용법을 살펴보겠습니다. tee 명령의 구문은 다음과 같습니다: tee[OPTION]...[FILE]...이 명령은 표준 입력에서 데이터를 읽고 데이터를 다음 위치에 저장합니다.

Angular 프레임워크의 구성 요소에 대한 기본 표시 동작은 블록 수준 요소에 대한 것이 아닙니다. 이 디자인 선택은 구성 요소 스타일의 캡슐화를 촉진하고 개발자가 각 구성 요소가 표시되는 방법을 의식적으로 정의하도록 장려합니다. CSS 속성 표시를 명시적으로 설정하면 Angular 구성 요소의 표시를 완전히 제어하여 원하는 레이아웃과 응답성을 얻을 수 있습니다.

Go 언어는 Google이 개발하여 2007년에 처음 출시된 오픈 소스 프로그래밍 언어입니다. 간단하고 배우기 쉽고 효율적이며 동시성이 높은 언어로 설계되었으며 점점 더 많은 개발자가 선호합니다. 이 기사에서는 Go 언어의 장점을 살펴보고 Go 언어에 적합한 몇 가지 애플리케이션 시나리오를 소개하며 구체적인 코드 예제를 제공합니다. 장점: 강력한 동시성: Go 언어에는 동시 프로그래밍을 쉽게 구현할 수 있는 경량 스레드 고루틴에 대한 지원이 내장되어 있습니다. Goroutin은 go 키워드를 사용하여 시작할 수 있습니다.

클라우드 컴퓨팅 분야에서 Linux의 광범위한 적용 클라우드 컴퓨팅 기술의 지속적인 개발 및 대중화와 함께 Linux는 오픈 소스 운영 체제로서 클라우드 컴퓨팅 분야에서 중요한 역할을 담당합니다. 안정성, 보안성 및 유연성으로 인해 Linux 시스템은 다양한 클라우드 컴퓨팅 플랫폼 및 서비스에서 널리 사용되며 클라우드 컴퓨팅 기술 개발을 위한 견고한 기반을 제공합니다. 이 기사에서는 클라우드 컴퓨팅 분야에서 Linux의 광범위한 애플리케이션을 소개하고 구체적인 코드 예제를 제공합니다. 1. 클라우드 컴퓨팅 플랫폼에서 리눅스의 애플리케이션 가상화 기술 가상화 기술

MySQL 타임스탬프는 날짜, 시간 또는 날짜와 시간을 저장할 수 있는 매우 중요한 데이터 유형입니다. 실제 개발 과정에서 타임스탬프를 합리적으로 사용하면 데이터베이스 운영 효율성을 높이고 시간 관련 쿼리 및 계산을 용이하게 할 수 있습니다. 이 기사에서는 MySQL 타임스탬프의 기능, 특징 및 애플리케이션 시나리오를 논의하고 특정 코드 예제를 통해 설명합니다. 1. MySQL 타임스탬프의 기능 및 특징 MySQL에는 두 가지 유형의 타임스탬프가 있는데, 하나는 TIMESTAMP입니다.

1. 먼저 작은 흰색 점을 클릭합니다. 2. 장치를 클릭하세요. 3. 더보기를 클릭하세요. 4. 애플리케이션 전환기를 클릭합니다. 5. 애플리케이션 배경을 닫으면 됩니다.
