>웹 프론트엔드 >View.js >Vue의 지침은 무엇이며 개발 시 적용 시나리오는 무엇입니까?

Vue의 지침은 무엇이며 개발 시 적용 시나리오는 무엇입니까?

PHPz
PHPz원래의
2023-06-11 16:01:401448검색

Vue.js는 매우 인기 있는 JavaScript 프레임워크입니다. Vue.js에서 지시문은 Vue.js에서 제공하는 특별한 HTML 속성으로, 템플릿과 DOM에서 표현식을 구문 분석할 수 있습니다. 이 기사에서는 Vue에서 일반적으로 사용되는 지침과 해당 응용 프로그램 시나리오에 대해 알아봅니다.

1. v-if/v-else-if/v-else

v-if 지시문은 표현식의 값을 기반으로 요소를 조건부로 렌더링하는 데 사용됩니다. 표현식이 true로 평가되면 요소가 렌더링됩니다. 표현식이 false로 평가되면 요소가 렌더링되지 않습니다.

v-else-if 및 v-else 명령어는 v-if의 "부정 조건"을 표현하는 데 사용됩니다. 즉, 이전 v-if 명령어가 조건을 확인하지 못한 경우 후속 v-else-if 또는 v-else 조건이 실행됩니다.

개발 중에 v-if는 사용자의 로그인 여부에 따라 로그인 양식이나 사용자 정보를 표시하는 등 특정 요소의 표시 여부를 제어하는 ​​데 자주 사용됩니다. 샘플 코드:

d477f9ce7bf77f53fbcf36bec1b69b7a
dc6dce4a544fdca2df29d5ac0ea9906b

<div v-if="user.loggedin">
  欢迎回来, {{ user.name }}!
</div>
<div v-else>
  <button @click="showLoginForm">请登录</button>
</div>

16b28748ea4df4d9c2150843fecfba68
21c97d3a051048b8e55e3c8f199a54b2

2 v-show

v-show 명령은 v-if와 비슷한 기능을 가지고 있습니다. 요소 표시 여부를 제어할 수도 있지만 v-if와 달리 v-show는 단순히 CSS 표시 속성을 전환합니다.

개발 중에 v-show는 일반적으로 드롭다운 메뉴의 확장 및 닫기를 제어하는 ​​등 요소의 가시성을 자주 전환하는 데 사용됩니다. 샘플 코드:

d477f9ce7bf77f53fbcf36bec1b69b7a
dc6dce4a544fdca2df29d5ac0ea9906b

<button @click="showMenu=!showMenu">下拉菜单</button>
<ul v-show="showMenu">
  <li>选项1</li>
  <li>选项2</li>
  <li>选项3</li>
</ul>

16b28748ea4df4d9c2150843fecfba68
21c97d3a051048b8e55e3c8f199a54b2

3. v-bind

v-bind 지시문은 하나 이상을 동적으로 바인딩하는 데 사용됩니다. HTML 속성, 바인딩할 수 있는 속성에는 클래스, 스타일, 제목 등이 포함됩니다. 바인딩 프로세스는 양방향입니다. JavaScript에서 데이터를 수정하면 HTML이 업데이트되고, HTML에서 속성을 수정하면 JavaScript에서 데이터가 업데이트될 수 있습니다.

개발 중 가장 일반적으로 사용되는 v-bind 시나리오는 다양한 상태에 따라 버튼의 색상 및 스타일을 설정하는 등 클래스 및 스타일 속성을 동적으로 바인딩하는 것입니다. 샘플 코드:

d477f9ce7bf77f53fbcf36bec1b69b7a
dc6dce4a544fdca2df29d5ac0ea9906b

<button
  :class="{active: isActive, disabled: isDisabled}"
  :style="{color: textColor, backgroundColor: bgColor}"
  :disabled="isDisabled"
>
  {{ buttonText }}
</button>

16b28748ea4df4d9c2150843fecfba68
21c97d3a051048b8e55e3c8f199a54b2

4 v-for

v-for 명령은 배열 또는 객체를 렌더링하는 데 사용됩니다. 루프 요소에서는 변수를 허용하고 배열 또는 개체의 각 항목을 이 변수에 차례로 할당한 다음 해당 요소를 렌더링할 수 있습니다.

개발 중에 v-for는 뉴스 목록, 제품 목록 등의 렌더링과 같은 목록 및 테이블 렌더링에 자주 사용됩니다. 샘플 코드:

d477f9ce7bf77f53fbcf36bec1b69b7a
dc6dce4a544fdca2df29d5ac0ea9906b

<ul>
  <li v-for="(item, index) in list" :key="index">{{ item }}</li>
</ul>

16b28748ea4df4d9c2150843fecfba68
21c97d3a051048b8e55e3c8f199a54b2

5. v-model

v-model 지시문은 양식 입력 요소 또는 사용자 정의를 바인딩합니다. 구성 요소의 값은 양방향 데이터 바인딩을 구현하는 데 사용됩니다. 양식의 값이 변경되면 해당 Vue 인스턴스의 데이터도 그에 따라 업데이트됩니다.

개발 중에 v-model은 입력 상자, 라디오 상자, 확인란, 드롭다운 상자 및 기타 구성 요소의 양방향 데이터 바인딩과 같은 양식 구현에 자주 사용됩니다. 샘플 코드:

d477f9ce7bf77f53fbcf36bec1b69b7a
dc6dce4a544fdca2df29d5ac0ea9906b

<input type="text" v-model="message">
<p>{{ message }}</p>

16b28748ea4df4d9c2150843fecfba68
21c97d3a051048b8e55e3c8f199a54b2

6 v-on

v-on 지시문은 이벤트 리스너를 바인딩하는 데 사용됩니다. DOM 이벤트, 커스텀 이벤트, 시스템 이벤트 등 다양한 이벤트를 수신할 수 있습니다. 이벤트가 트리거되면 해당 메서드가 호출됩니다.

개발 중에 v-on은 버튼 클릭, 키보드 입력, 마우스 스크롤 등과 같은 사용자 상호 작용 이벤트를 처리하는 데 자주 사용됩니다. 샘플 코드:

d477f9ce7bf77f53fbcf36bec1b69b7a
dc6dce4a544fdca2df29d5ac0ea9906b

<button @click="incrementCount">{{ count }}</button>

16b28748ea4df4d9c2150843fecfba68
21c97d3a051048b8e55e3c8f199a54b2

7 v-text/v-html

v-text 지시문은 변경하는 데 사용됩니다. 요소의 textContent가 지시문의 값으로 설정된 경우 텍스트 형식으로만 출력되며 HTML을 구문 분석하지 않습니다.

v-html 지시문은 요소의 innerHTML을 지시문의 값으로 설정하는 데 사용됩니다. HTML 태그는 구문 분석될 수 있지만 XSS의 위험이 있습니다.

개발 시 v-text/v-html 지시문은 보안 위험을 증가시키므로 주의해서 사용해야 합니다. 따라서 서식 있는 텍스트 편집기의 출력 렌더링과 같이 HTML에 신뢰할 수 있는 일부 콘텐츠를 삽입하는 데에만 사용해야 합니다. 샘플 코드:

d477f9ce7bf77f53fbcf36bec1b69b7a
dc6dce4a544fdca2df29d5ac0ea9906b

<div v-text="content"></div>
<div v-html="content"></div>

16b28748ea4df4d9c2150843fecfba68
21c97d3a051048b8e55e3c8f199a54b2

이 기사에서는 Vue에서 일반적으로 사용되는 지침과 해당 응용 프로그램 시나리오를 소개합니다. js 프레임워크의 중요한 기능은 개발 효율성을 효과적으로 향상시키는 동시에 Vue.js 애플리케이션이 더욱 풍부한 대화형 효과와 사용자 경험을 갖도록 만들 수 있습니다. 따라서 Vue.js 프레임워크를 사용할 때 이러한 지침을 숙지하는 것이 매우 중요합니다.

위 내용은 Vue의 지침은 무엇이며 개발 시 적용 시나리오는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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