> php教程 > PHP开发 > Vue 개발 경험 및 기술 공유

Vue 개발 경험 및 기술 공유

高洛峰
풀어 주다: 2016-12-08 15:43:39
원래의
1661명이 탐색했습니다.

이 시리즈는 Vue 개발 1년 동안 제가 요약한 경험과 기술 중 일부를 기록합니다.

성능 향상을 위해 Object.freeze() 사용

Object.freeze()는 ES5의 새로운 기능으로, 객체가 수정되는 것을 방지하기 위해 객체를 고정할 수 있습니다.

vue 1.0.18+에서는 이를 지원합니다. 데이터 또는 vuex에서 고정을 사용하여 고정된 객체의 경우 vue는 getter 및 setter를 변환하지 않습니다.

대규모 배열이나 객체가 있고 데이터가 수정되지 않을 것이라고 확신하는 경우 Object.freeze()를 사용하면 성능이 크게 향상될 수 있습니다. 실제 개발에서 이러한 개선은 약 5~10배이며, 데이터 양에 따라 그 배수도 증가합니다.

게다가 Object.freeze()는 값을 고정하고 변수에 대한 참조를 계속 대체할 수 있습니다. 예:

{{ item.value }}

new Vue({
 data: {
 // vue不会对list里的object做getter、setter绑定
 list: Object.freeze([
  { value: 1 },
  { value: 2 }
 ])
 },
 created () {
 // 界面不会有响应
 this.list[0].value = 100;
 
 // 下面两种做法,界面都会响应
 this.list = [
  { value: 100 },
  { value: 200 }
 ];
 this.list = Object.freeze([
  { value: 100 },
  { value: 200 }
 ]);
 }
})
로그인 후 복사

Vue의 문서에는 이 기능이 언급되어 있지 않지만 순수하게 표시되는 빅 데이터의 경우 Object.freeze를 사용하여 성능을 향상시킬 수 있는 매우 실용적인 접근 방식입니다.

vm.$compile을 사용하여 dom 컴파일

$compile 함수를 사용하여 vue를 수동으로 호출하여 dom을 컴파일할 수 있습니다. 이 기능은 jQuery 플러그인에서 생성된 html이나 서버에서 반환된 html을 처리해야 할 때 유용할 수 있습니다. 그러나 이는 비공개 API이므로 언제든지 변경될 수 있으며 이러한 접근 방식은 Vue의 철학에 어긋납니다. 최후의 수단으로만 사용하십시오.

new Vue({
 data: {
 value: 'demo'
 },
 created () {
 let dom = document.createElement('div');
 dom.innerHTML = '{{ value }}';
 this.$compile(dom);
 }
})
로그인 후 복사

track-by="$index"의 합리적인 사용

track-by는 Vue for 루프에서 제공하는 최적화 방법입니다. . 여러 v-for에서 동일한 ID로 DOM을 재사용할 수 있습니다. 데이터에 고유 ID가 없는 경우 track-by="$index"를 사용하도록 선택할 수도 있지만 몇 가지 부작용을 알고 있어야 합니다.

예:

new Vue({
 data: {
 list: [1, 2, 3]
 }
})
<div id="demo-1">
 <p v-for="item in list">{{ item }}</p>
</div>
<div id="demo-2">
 <p v-for="item in list" track-by="$index">{{ item }}</p>
</div>
로그인 후 복사

이때 this.list = [4, 5, 6]을 실행합니다. F12를 통해 관찰합니다. 이때 데모-1의 DOM은 모두 삭제된 후 목록을 재활용하여 DOM을 생성합니다. 그러나 데모-2에서는 DOM을 삭제하지 않고 텍스트 그리드만 4, 5, 5로 변경합니다. 그리고 6. 이는 v-for에서 동일한 $index가 있는 dom을 두 번 재사용하는 track-by="$index"의 효과입니다.

이것은 좋은 최적화 방법이지만 모든 시나리오에 적용할 수 있는 것은 아닙니다. 예를 들어 루프에 양식 컨트롤이나 하위 구성 요소가 포함되어 있으면 DOM이 삭제되고 재생성되지 않으므로 두 번째 실행이 발생합니다. v-for, 원래 양식 컨트롤의 값은 변경되지 않습니다. https://jsfiddle.net/jysboza9/1/

지시문을 남용하지 마세요

. 인터넷에는 모든 DOM 작업이 명령어로 캡슐화되어야 한다는 말이 있습니다. 실제 개발에서는 이 도그마를 따라서는 안 된다고 생각합니다. 명령어 사용 여부는 DOM 조작 여부가 아니라 구현하는 기능에 따라 달라집니다. 예를 들어 vue를 사용하여 jQuery 플러그인을 캡슐화하려는 경우 다음 캡슐화 방법 중 어떤 것이 더 좋은지 살펴보겠습니다.

<!-- component -->
<datepicker></datepicker>
<!-- directive -->
<div v-datepicker="{options}"></div>
로그인 후 복사

개인적으로 , 나는 그것이 의심할 여지 없이 첫 번째 방법이라고 생각합니다. Datepicker는 독립적인 구성 요소이므로 내부적으로 DOM을 작동하는지 또는 jQuery 플러그인을 캡슐화하는지 여부를 신경 쓸 필요가 없습니다.

그럼 언제 명령어를 사용하시나요? 브라우저에서 기본적으로 제공하는 명령을 살펴보겠습니다.

<a title="这是一个指令"></a>
<p title="这是一个指令"></p>
<div title="这是一个指令"></div>
로그인 후 복사

제목 속성은 다양한 태그에 대한 도구 설명 기능을 제공하는 명령입니다. 지시어는 다양한 태그와 구성 요소에 동일한 기능을 제공할 수 있는 독립적인 기능을 나타내야 합니다.


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