> 웹 프론트엔드 > View.js > Vue에서 조건부 렌더링을 구현하는 방법

Vue에서 조건부 렌더링을 구현하는 방법

WBOY
풀어 주다: 2023-10-15 10:06:24
원래의
592명이 탐색했습니다.

Vue에서 조건부 렌더링을 구현하는 방법

Vue에서 조건부 렌더링을 구현하는 방법

Vue는 널리 사용되는 JavaScript 프레임워크이며 핵심 기능은 데이터 기반 UI 렌더링을 구현하는 것입니다. Vue에서는 조건부 판단을 통해 렌더링된 컨텐츠를 쉽게 제어하고 조건부 렌더링 기능을 구현할 수 있습니다. 이 기사에서는 Vue에서 조건부 렌더링을 사용하여 다양한 상황에서 UI 표시를 제어하는 ​​방법을 소개하고 구체적인 코드 예제를 제공합니다.

Vue에는 조건부 렌더링의 두 가지 주요 방법이 있습니다: v-if 명령과 v-show 명령입니다. 이 두 명령어의 사용법은 비슷하지만 기본 구현에는 약간의 차이가 있습니다.

  1. v-if 지시문 사용

v-if 지시문은 true 또는 false 표현식을 기반으로 요소가 렌더링되는지 여부를 제어할 수 있습니다. 표현식이 true이면 요소가 DOM으로 렌더링되고, 표현식이 false이면 DOM에서 제거됩니다. HTML 요소에 v-if 지시문을 사용하여 조건부 렌더링을 달성할 수 있습니다.

예를 들어 isShow 값에 따라 버튼을 표시할지 여부를 결정하는 상태 변수 isShow가 있습니다. 다음과 같이 HTML 템플릿에서 v-if 지시문을 사용할 수 있습니다.

<button v-if="isShow">按钮</button>
로그인 후 복사

Vue 인스턴스의 데이터 옵션에 isShow 변수를 선언하고 초기 값을 할당합니다. isShow 값을 수정하여 버튼을 표시하거나 숨길 수 있습니다.

var app = new Vue({
  el: '#app',
  data: {
    isShow: true  // 是否显示按钮
  }
});
로그인 후 복사
로그인 후 복사

isShow 값이 true이면 버튼이 DOM으로 렌더링되고, isShow 값이 false이면 버튼이 DOM에서 제거됩니다.

  1. v-show 명령 사용

v-show 명령은 v-if 명령과 유사하며 true 또는 false 표현식을 기반으로 요소의 표시 및 숨기기를 제어할 수 있습니다. 차이점은 v-show 지시문은 DOM에서 요소를 직접 제거하는 대신 요소의 CSS 속성 표시 값만 제어한다는 것입니다. 식이 true이면 요소가 표시되고, 식이 false이면 요소가 숨겨집니다. HTML 템플릿에서 v-show 지시문을 사용하는 것도 매우 간단합니다.

<button v-show="isShow">按钮</button>
로그인 후 복사

마찬가지로 Vue 인스턴스의 데이터 옵션에서 isShow 변수를 선언하고 초기 값을 할당합니다. isShow 값을 수정하여 버튼 표시 및 숨기기를 제어할 수 있습니다.

var app = new Vue({
  el: '#app',
  data: {
    isShow: true  // 是否显示按钮
  }
});
로그인 후 복사
로그인 후 복사

isShow 값이 true이면 버튼이 표시되고, isShow 값이 false이면 버튼이 숨겨집니다. v-if와 비교하여 v-show는 더 나은 성능을 가지며 표시 상태를 자주 전환해야 하는 상황에 적합합니다.

요약:

Vue의 조건부 렌더링 기능은 v-if 지시어와 v-show 지시어를 통해 구현할 수 있습니다. v-if 지시문은 표현식이 참인지 거짓인지에 따라 요소를 동적으로 렌더링하거나 제거할 수 있는 반면, v-show 지시문은 CSS 속성을 제어하여 요소를 표시하거나 숨깁니다. 더 나은 성능과 사용자 경험을 달성하려면 실제 요구 사항에 따라 적절한 조건부 렌더링 방법을 선택하십시오.

위는 Vue에서 조건부 렌더링을 구현하는 방법에 대한 소개 및 코드 예제입니다. 자신의 Vue 프로젝트에서 조건부 렌더링을 사용해 보려면 기사의 단계를 따르세요. 도움이 되길 바랍니다!

위 내용은 Vue에서 조건부 렌더링을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿