VueJS-반응 형 인터페이스

VueJS는 동적으로 추가되는 속성에 반응성을 추가하는 옵션을 제공합니다. 이미 vue 인스턴스를 생성했으며 watch 속성을 추가해야한다고 가정합니다. 다음과 같이 할 수 있습니다-

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "app">
         <p style = "font-size:25px;">Counter: {{ counter }}</p>
         <button @click = "counter++" style = "font-size:25px;">Click Me</button>
      </div>
      <script type = "text/javascript">
         var vm = new Vue({
            el: '#app',
            data: {
               counter: 1
            }
         });
         vm.$watch('counter', function(nval, oval) {
            alert('Counter is incremented :' + oval + ' to ' + nval + '!');
         });
         setTimeout(
            function(){
               vm.counter = 20;
            },2000
         );
      </script>
   </body>
</html>

데이터 개체에 1로 정의 된 속성 카운터가 있습니다. 버튼을 클릭하면 카운터가 증가합니다.

Vue 인스턴스가 이미 생성되었습니다. 시계를 추가하려면 다음과 같이해야합니다.

vm.$watch('counter', function(nval, oval) {
   alert('Counter is incremented :' + oval + ' to ' + nval + '!');
});

$ watch를 사용하여 vue 인스턴스 외부에 시계를 추가해야합니다. 카운터 속성의 값 변경을 보여주는 경고가 추가되었습니다. 카운터 값을 20으로 설정하는 타이머 함수, 즉 setTimeout도 추가되었습니다.

setTimeout(
   function(){
      vm.counter = 20;
   },2000
);

카운터가 변경 될 때마다 다음 스크린 샷과 같이 watch 메서드의 경고가 발생합니다.

VueJS는 속성 추가 및 삭제를 감지 할 수 없습니다. 가장 좋은 방법은 항상 속성을 선언하는 것입니다.이 속성은 Vue 인스턴스에서 미리 반응해야합니다. 런타임에 속성을 추가해야하는 경우 Vue 전역, Vue.set 및 Vue.delete 메서드를 사용할 수 있습니다.

Vue.set

이 메서드는 개체에 속성을 설정하는 데 도움이됩니다. Vue가 속성 추가를 감지 할 수없는 한계를 극복하는 데 사용됩니다.

통사론

Vue.set( target, key, value )

어디,

대상 : 객체 또는 배열 일 수 있습니다.

key : 문자열 또는 숫자 일 수 있습니다.

값 : 모든 유형 가능

예를 살펴 보겠습니다.

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "app">
         <p style = "font-size:25px;">Counter: {{ products.id }}</p>
         <button @click = "products.id++" style = "font-size:25px;">Click Me</button>
      </div>
      <script type = "text/javascript">
         var myproduct = {"id":1, name:"book", "price":"20.00"};
         var vm = new Vue({
            el: '#app',
            data: {
               counter: 1,
               products: myproduct
            }
         });
         vm.products.qty = "1";
         console.log(vm);
         vm.$watch('counter', function(nval, oval) {
            alert('Counter is incremented :' + oval + ' to ' + nval + '!');
         });
      </script>
   </body>
</html>

위의 예에는 다음 코드를 사용하여 처음에 만든 변수 myproduct가 있습니다.

var myproduct = {"id":1, name:"book", "price":"20.00"};

다음과 같이 Vue 인스턴스의 데이터 객체에 제공됩니다.

var vm = new Vue({
   el: '#app',
   data: {
      counter: 1,
      products: myproduct
   }
});

Vue 인스턴스가 생성 된 후 myproduct 배열에 속성을 하나 더 추가하려고합니다. 다음과 같이 할 수 있습니다-

vm.products.qty = "1";

콘솔에서 출력을 봅시다.

위와 같이 제품에 수량이 추가됩니다. 기본적으로 반응성을 추가하는 get / set 메서드는 ID, 이름 및 가격에 대해 사용할 수 있으며 수량에는 사용할 수 없습니다.

vue 객체를 추가하는 것만으로는 반응성을 얻을 수 없습니다. VueJS는 대부분 처음에 모든 속성이 생성되기를 원합니다. 그러나 나중에 추가해야 할 경우 Vue.set을 사용할 수 있습니다. 이를 위해 vue global, 즉 Vue.set을 사용하여 설정해야합니다.

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "app">
         <p style = "font-size:25px;">Counter: {{ products.id }}</p>
         <button @click = "products.id++" style = "font-size:25px;">Click Me</button>
      </div>
      <script type = "text/javascript">
         var myproduct = {"id":1, name:"book", "price":"20.00"};
         var vm = new Vue({
            el: '#app',
            data: {
               counter: 1,
               products: myproduct
            }
         });
         Vue.set(myproduct, 'qty', 1);
         console.log(vm);
         vm.$watch('counter', function(nval, oval) {
            alert('Counter is incremented :' + oval + ' to ' + nval + '!');
         });
      </script>
   </body>
</html>

Vue.set을 사용하여 다음 코드를 사용하여 배열에 수량을 추가했습니다.

Vue.set(myproduct, 'qty', 1);

우리는 vue 객체를 위로했고 다음은 출력입니다.

이제 Vue.set을 사용하여 추가 된 수량에 대한 get / set을 볼 수 있습니다.

Vue.delete

이 기능은 속성을 동적으로 삭제하는 데 사용됩니다.

Vue.delete( target, key )

어디,

대상 : 객체 또는 배열 일 수 있습니다.

키 : 문자열 또는 숫자 일 수 있습니다.

속성을 삭제하려면 다음 코드와 같이 Vue.delete를 사용할 수 있습니다.

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "app">
         <p style = "font-size:25px;">Counter: {{ products.id }}</p>
         <button @click = "products.id++" style = "font-size:25px;">Click Me</button>
      </div>
      <script type = "text/javascript">
         var myproduct = {"id":1, name:"book", "price":"20.00"};
         var vm = new Vue({
            el: '#app',
            data: {
               counter: 1,
               products: myproduct
            }
         });
         Vue.delete(myproduct, 'price');
         console.log(vm);
         vm.$watch('counter', function(nval, oval) {
            alert('Counter is incremented :' + oval + ' to ' + nval + '!');
         });
      </script>
   </body>
</html>

위의 예에서는 Vue.delete를 사용하여 다음 코드를 사용하여 배열에서 가격을 삭제했습니다.

Vue.delete(myproduct, 'price');

다음은 콘솔에서 볼 수있는 출력입니다.

삭제 후 가격이 삭제됨에 따라 아이디와 이름 만 볼 수 있습니다. 또한 get / set 메서드가 삭제 된 것을 알 수 있습니다.