>웹 프론트엔드 >JS 튜토리얼 >VUE 어레이 업데이트에 대한 자세한 설명

VUE 어레이 업데이트에 대한 자세한 설명

小云云
小云云원래의
2017-12-19 09:03:212614검색

Vue 배열 업데이트에 관해서는 VUE 배열 업데이트 문제를 주로 소개합니다. Vue가 데이터 변경 사항을 모니터링하는 방법을 소개합니다. 필요한 친구들이 참고하면 도움이 될 것입니다.

1. 데이터 방식 분류:

(1) 원래 배열이 변경됨

push
pop
unshift
Shift
reverse
sort
splice

(2) 원래 배열은 변경되지 않고 새 배열로 변경됨 배열이 생성됩니다

Slice
concat
filter

원래 배열을 변경하는 방법은 뷰를 직접 업데이트하면 됩니다.

원래 배열이 변경되지 않은 메서드의 경우 원래 배열을 새 배열로 교체하여 보기를 변경할 수 있습니다.

샘플 코드:


<!DOCTYPE html>
<html lang="zh">
  <head>
    <meta charset="UTF-8" />
    <title>vue示例</title>
  </head>
  <body>
    <p id="app">
      <ul>
        <template v-for="book in books">
          <li>书名:{{book.name}}</li>
          <li>作者:{{book.author}}</li>
        </template>
      </ul>
    </p>
    <script src="https://cdn.bootcss.com/vue/2.5.9/vue.min.js"></script>
    <script type="text/javascript">
      var app = new Vue({
        el: &#39;#app&#39;,
        data: {
          books: [{
              name: &#39;vuejs&#39;,
              author: &#39;a&#39;
            },
            {
              name: &#39;js高级&#39;,
              author: &#39;b&#39;
            },
            {
              name: &#39;java&#39;,
              author: &#39;c&#39;
            }
          ]
        }
      });
      //直接可以使得视图改变
      //app.books.push({name: &#39;c++&#39;,author: &#39;d&#39;});
      //需要更新原数组
      app.books = app.books.concat([{name: &#39;c++&#39;,author: &#39;d&#39;}]);
    </script>
  </body>
</html>

참고: 다음은 뷰 업데이트를 트리거하지 않습니다.

(1) 인덱스별로 항목을 직접 설정합니다.

(2) 배열 길이 app.books.length=1을 수정합니다.

원본 배열을 변경하고 싶지 않은 경우 계산된 속성을 사용하여 다음과 같이 배열을 필터링할 수 있습니다.


 <!DOCTYPE html>
<html lang="zh">
  <head>
    <meta charset="UTF-8" />
    <title>vue示例</title>
  </head>
  <body>
    <p id="app">
      <ul>
        <template v-for="book in filterBooks">
          <li>书名:{{book.name}}</li>
          <li>作者:{{book.author}}</li>
        </template>
      </ul>
    </p>
    <script src="https://cdn.bootcss.com/vue/2.5.9/vue.min.js"></script>
    <script type="text/javascript">
      var app = new Vue({
        el: &#39;#app&#39;,
        data: {
          books: [{
              name: &#39;vuejs&#39;,
              author: &#39;a&#39;
            },
            {
              name: &#39;js高级111&#39;,
              author: &#39;b&#39;
            },
            {
              name: &#39;java33333&#39;,
              author: &#39;c&#39;
            }
          ]
        },
        computed:{
          filterBooks:function(){
            return this.books.sort(function(a,b){
              return a.name.length>b.name.length?1:-1
            })
          }
        }
      });
    </script>
  </body>
</html>

그렇다면 Vue는 어떻게 데이터 변경을 모니터링합니까?

1) 변경 사항을 추적하는 방법

각 구성 요소 인스턴스에는 해당 감시자 인스턴스 개체가 있으며, 이는 구성 요소 렌더링 프로세스 중에 속성을 종속성으로 기록합니다. 나중에 종속성의 설정자가 호출되면 감시자에게 알림이 전달됩니다. 다시 계산되어 관련 구성 요소가 업데이트됩니다.

2) 변경 감지 문제

최신 JavaScript의 제한 사항(및 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, &#39;b&#39;, 2)

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

위 내용은 VUE 어레이 업데이트에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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