> 웹 프론트엔드 > View.js > Vue 응답성 원칙에 대한 심층적인 이해

Vue 응답성 원칙에 대한 심층적인 이해

青灯夜游
풀어 주다: 2020-10-12 17:33:58
앞으로
1947명이 탐색했습니다.

Vue 응답성 원칙에 대한 심층적인 이해

Vue의 가장 주목할만한 기능 중 하나는 눈에 띄지 않는 반응성 시스템입니다. 모델 레이어(model)는 그냥 일반적인 JS 객체이며, 이를 수정하면 뷰(view)가 업데이트됩니다. 이로 인해 상태 관리가 매우 간단하고 직관적이게 되지만 몇 가지 일반적인 문제를 방지하려면 상태 관리가 어떻게 작동하는지 이해하는 것이 중요합니다.

이 글에서는 Vue 반응형 시스템의 기본 세부 사항을 자세히 소개합니다.

변경 사항 추적

Vue 인스턴스의 데이터 옵션에 일반 JS 객체를 전달합니다. Vue는 이 객체의 모든 속성을 탐색하고 Object.defineProperty를 사용하여 이러한 모든 속성을 getter/setter로 변환합니다.

Object.defineProperty는 ES5에서만 지원되며 심싱할 수 없습니다. 이것이 바로 Vue가 IE8 브라우저를 지원하지 않는 이유입니다.

사용자는 getter/setter를 볼 수 없지만 내부적으로 Vue가 종속성을 추적하고 속성에 액세스하고 수정될 때 변경 사항을 알릴 수 있습니다.

각 구성 요소 인스턴스에는 구성 요소 렌더링 중에 사용되는 해당 감시자 인스턴스 개체가 있습니다. 종속성으로 설정한 다음 종속성의 setter가 호출되면 감시자에게 다시 계산하라는 알림이 전달되어 관련 구성 요소가 업데이트됩니다.

Vue 응답성 원칙에 대한 심층적인 이해

변경 감지

최신 JS의 제한 사항(및 Object.observe의 지원 중단)으로 인해 Vue는 객체 속성의 추가 또는 삭제를 감지할 수 없습니다. Vue는 인스턴스를 초기화할 때 속성에 대해 getter/setter 변환 프로세스를 수행하므로 Vue가 응답할 수 있도록 변환하려면 속성이 데이터 객체에 존재해야 합니다.

var vm = new Vue({
  data:{
    a:1
  }
})
// `vm.a` 是响应的
vm.b = 2
// `vm.b` 是非响应的
로그인 후 복사

Vue는 이미 생성된 인스턴스에 새로운 루트 수준 반응 속성을 동적으로 추가하는 것을 허용하지 않습니다. 그러나 Vue.set(object, key, value) 메소드를 사용하여 중첩된 객체에 응답 속성을 추가하는 것이 가능합니다.

Vue.set(vm.someObject, 'b', 2)
로그인 후 복사

전역 Vue.set 메소드의 별칭이기도 한 vm.$set 인스턴스 메소드를 사용할 수도 있습니다.

this.$set(this.someObject,'b',2)
로그인 후 복사

때로는 Object.sign() 또는 _.extend() 메서드를 사용하여 속성을 추가하는 등 기존 객체에 일부 속성을 추가하고 싶을 때가 있습니다. 그러나 개체에 추가된 새 속성은 업데이트를 트리거하지 않습니다. 이 경우 원래 개체의 속성과 새 속성을 포함하는 새 개체를 만들 수 있습니다.

// 代替 `Object.assign(this.someObject, { a: 1, b: 2 })`
this.someObject = Object.assign({}, this.someObject, { a: 1, b: 2 })
로그인 후 복사

반응 속성 선언

Vue에서는 루트 수준 반응 속성을 동적으로 추가하는 것을 허용하지 않으므로 인스턴스를 초기화하기 전에 루트 수준 반응 속성이 null 값일지라도 선언해야 합니다.

var vm = new Vue({
  data: {
    // 声明 message 为一个空值字符串
    message: ''
  },
  template: &#39;<div>{{ message }}</div>&#39;
})
// 之后设置 `message` 
vm.message = &#39;Hello!&#39;
로그인 후 복사

데이터 옵션에 메시지가 선언되지 않은 경우 Vue는 액세스하려는 속성이 존재하지 않는다고 렌더링 기능에 경고합니다.

이 제한에는 기술적인 이유가 있습니다. 이는 종속성 추적 시스템에서 특정 유형의 예외 사례를 제거하고 유형 검사 시스템의 도움으로 Vue 인스턴스가 더 효율적으로 실행되도록 합니다.

또한 코드 유지 관리 측면에서 중요한 고려 사항이 있습니다. 데이터 객체는 구성 요소 상태의 요약과 같습니다. 모든 반응 속성을 미리 선언하면 나중에 다시 읽을 때 구성 요소 코드를 더 쉽게 이해할 수 있습니다. 개발자는 그것을 읽었습니다.

비동기 업데이트 대기열

Vue는 DOM 업데이트를 비동기적으로 수행합니다. 데이터 변경 사항이 관찰되는 한 Vue는 대기열을 열고 동일한 이벤트 루프에서 발생하는 모든 데이터 변경 사항을 버퍼링합니다. 동일한 감시자가 여러 번 트리거되면 대기열에 한 번만 푸시됩니다.

불필요한 계산과 DOM 작업을 방지하려면 버퍼링 중 이러한 종류의 중복 제거가 매우 중요합니다. 그런 다음 다음 이벤트 루프 "틱"에서 Vue는 큐를 플러시하고 실제(중복 제거된) 작업을 수행합니다.

Vue는 내부적으로 비동기 대기열에 기본 Promise.then 및 MutationObserver를 사용하려고 시도합니다. 실행 환경이 이를 지원하지 않으면 setTimeout(fn, 0)이 대신 사용됩니다

예를 들어, vm.someData='new value' 설정되면 구성 요소가 즉시 다시 렌더링되지 않습니다. 대기열이 플러시되면 이벤트 루프 대기열이 지워지는 다음 "틱"에서 구성 요소가 업데이트됩니다. 대부분의 경우 이 프로세스에 대해 걱정할 필요가 없지만 DOM 상태가 업데이트된 후에 무언가를 수행하려는 경우 약간 까다로울 수 있습니다.

Vue.js는 일반적으로 개발자가 "데이터 기반" 기반으로 생각하고 DOM과의 직접적인 접촉을 피하도록 권장하지만 그렇게 해야 할 때가 있습니다. 데이터 변경 후 Vue가 DOM 업데이트를 완료할 때까지 기다리려면 데이터 변경 직후 Vue.nextTick(콜백)을 사용할 수 있습니다. 이 콜백 함수는 DOM 업데이트가 완료된 후에 호출됩니다.

<div id="example">{{message}}</div>
로그인 후 복사
var vm = new Vue({
  el: &#39;#example&#39;,
  data: {
    message: &#39;123&#39;
  }
})
vm.message = &#39;new message&#39; // 更改数据
vm.$el.textContent === &#39;new message&#39; // false
Vue.nextTick(function () {
  vm.$el.textContent === &#39;new message&#39; // true
})
로그인 후 복사

글로벌 Vue가 필요하지 않기 때문에 구성 요소 내에서 vm.$nextTick() 인스턴스 메서드를 사용하는 것이 특히 편리하며 콜백 함수의 이 메서드는 자동으로 현재 Vue 인스턴스에 바인딩됩니다.

Vue.component(&#39;example&#39;, {
  template: &#39;<span>{{ message }}</span>&#39;,
  data: function () {
    return {
      message: &#39;没有更新&#39;
    }
  },
  methods: {
    updateMessage: function () {
      this.message = &#39;更新完成&#39;
      console.log(this.$el.textContent) // => &#39;没有更新&#39;
      this.$nextTick(function () {
        console.log(this.$el.textContent) // => &#39;更新完成&#39;
      })
    }
  }
})
로그인 후 복사

관련 추천:

2020년 프런트엔드 vue 인터뷰 질문 요약(답변 포함)

vue 튜토리얼 추천: 2020년 최신 5개 vue.js 비디오 튜토리얼 선택

더 많은 프로그래밍 관련 지식을 보려면 프로그래밍 소개를 방문하세요! !

위 내용은 Vue 응답성 원칙에 대한 심층적인 이해의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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