vue.js 지시문이란 무엇입니까?

coldplay.xixi
풀어 주다: 2020-11-30 14:46:37
원래의
2160명이 탐색했습니다.

vue.js 명령어는 [v-if] 및 [v-show]와 같은 많은 내장 명령어입니다. 이러한 풍부한 명령어는 대부분의 비즈니스 요구를 충족할 수 있습니다. , 업데이트].

vue.js 지시문이란 무엇입니까?

이 튜토리얼의 운영 환경: windows10 시스템, vue2.9, 이 기사는 모든 브랜드의 컴퓨터에 적용 가능합니다.

【추천 관련 기사: vue.js

질문 1: vue.js의 사용자 정의 지침이란 무엇입니까?

기본 DOM을 작동하기 위한 일부 명령을 사용자 정의

추가 참조

Vue에는 v-if 및 v-show와 같은 많은 내장 명령이 있습니다. 그러나 이러한 풍부한 명령은 대부분의 비즈니스 요구를 충족할 수 있습니다. 특별한 기능이 필요하지만 여전히 DOM에서 낮은 수준의 작업을 수행하고 싶고 사용자 정의 지침을 사용해야 합니다.

질문 2: 사용자 정의 명령어의 여러 후크 기능

  • bind: 한 번만 호출되며, 명령어가 처음으로 요소에 바인딩될 때 호출됩니다. 여기에서 일회성 초기화 설정을 수행할 수 있습니다.

  • inserted: 바인딩된 요소가 상위 노드에 삽입될 때 호출됩니다(상위 노드만 존재하도록 보장되지만 반드시 문서에 삽입될 필요는 없습니다).

  • update: 구성 요소의 VNode가 업데이트될 때 호출되지만 해당 하위 VNode가 업데이트되기 전에 발생할 수 있습니다. 지시어의 값은 변경되었을 수도 있고 변경되지 않았을 수도 있습니다. 하지만 업데이트 전과 후의 값을 비교하면 불필요한 템플릿 업데이트를 무시할 수 있습니다.

  • comComponentUpdated: 명령어가 있는 구성 요소의 모든 VNode와 해당 하위 VNode가 업데이트된 후에 호출됩니다.

  • unbind: 한 번만 호출되며, 명령이 요소에서 바인딩 해제될 때 호출됩니다.

질문 3: 후크 기능 매개변수

el을 제외한 다른 모든 매개변수는 읽기 전용이어야 하며 수정하면 안 됩니다. 후크 간에 데이터를 공유해야 하는 경우 요소의 데이터세트를 통해 수행하는 것이 좋습니다.

명령어 후크 기능은 다음 매개변수로 전달됩니다.

1.el: 명령에 바인딩된 요소를 사용하여 DOM을 직접 작동할 수 있습니다.

2. 바인딩: 다음 속성을 포함하는 개체:

  • name: v- 접두사를 제외한 명령 이름.

  • value: 지시문의 바인딩 값(예: v-my-directive="1 + 1"), 바인딩 값은 2입니다.

  • oldValue: 명령 바인딩의 이전 값으로, update 및 componentUpdated 후크에서만 사용할 수 있습니다. 값이 변경되었는지 여부에 관계없이 사용할 수 있습니다.

  • 표현식: 문자열 형식의 명령어 표현입니다. 예를 들어 v-my-directive="1 + 1"에서 표현식은 "1 + 1"입니다.

  • arg: 명령에 전달되는 매개변수, 선택사항. 예를 들어 v-my-directive:foo에서 매개변수는 "foo"입니다.

  • modifiers: 수정자를 포함하는 개체입니다. 예를 들어 v-my-directive.foo.bar에서 수정자 개체는 { foo: true, bar: true }입니다.

  • vnode: Vue 컴파일로 생성된 가상 노드입니다.

3.oldVnode: 이전 가상 노드로, update 및 componentUpdated 후크에서만 사용할 수 있습니다.

질문 4: vue-cli에서 사용자 정의 지침을 사용하는 방법은 무엇입니까?

파일 구조:

.
├── src
│   ├── directives
│   │    ├── index.js
│   │    ├── modules
│   └── main.js
└── ...
로그인 후 복사

모듈 아래에 새 foucs.js 만들기

// 聚焦指令
export default {
  bind (el, binding, vnode) {},
  inserted (el, binding, vnode) {
    el.focus()
  },
  update (el, binding, vnode) {},
  componentUpdated (el, binding, vnode) {},
  unbind (el, binding, vnode) {}
}
로그인 후 복사

src/directives/index.js 아래

import focus from './modules/focus'
export {focus}
로그인 후 복사

src/main.js 아래에서 지시어를 사용하여 지침 맞춤화

//引入自定义指令
import * as directives from './directives'
//注册指令
Object.keys(directives).forEach(k => Vue.directive(k, directives[k]));
로그인 후 복사

In. Vue 구성 요소에서

<input v-focus type="text" />
로그인 후 복사

사용 관련: JavaScript(비디오)

위 내용은 vue.js 지시문이란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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