VueJS-믹스 인

믹스 인은 기본적으로 구성 요소와 함께 사용됩니다. 컴포넌트간에 재사용 가능한 코드를 공유합니다. 컴포넌트가 mixin을 사용하면 mixin의 모든 옵션이 컴포넌트 옵션의 일부가됩니다.

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "databinding"></div>
      <script type = "text/javascript">
         var vm = new Vue({
            el: '#databinding',
            data: {
            },
            methods : {
            },
         });
         var myMixin = {
            created: function () {
               this.startmixin()
            },
            methods: {
               startmixin: function () {
                  alert("Welcome  to mixin example");
               }
            }
         };
         var Component = Vue.extend({
            mixins: [myMixin]
         })
         var component = new Component();
      </script>
   </body>
</html>

산출

믹스 인과 구성 요소에 겹치는 옵션이 포함되어 있으면 다음 예제와 같이 병합됩니다.

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "databinding"></div>
      <script type = "text/javascript">
         var mixin = {
            created: function () {
               console.log('mixin called')
            }
         }
         new Vue({
            mixins: [mixin],
            created: function () {
               console.log('component called')
            }
         });
      </script>
   </body>
</html>

이제 mixin과 vue 인스턴스에 동일한 메서드가 생성되었습니다. 이것은 콘솔에서 볼 수있는 출력입니다. 보시다시피 vue와 mixin의 옵션이 병합됩니다.

메서드에 동일한 함수 이름이 있으면 기본 vue 인스턴스가 우선합니다.

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "databinding"></div>
      <script type = "text/javascript">
         var mixin = {
            methods: {
               hellworld: function () {
                  console.log('In HelloWorld');
               },
               samemethod: function () {
                  console.log('Mixin:Same Method');
               }
            }
         };
         var vm = new Vue({
            mixins: [mixin],
            methods: {
               start: function () {
                  console.log('start method');
               },
               samemethod: function () {
                  console.log('Main: same method');
               }
            }
         });
         vm.hellworld();
         vm.start();
         vm.samemethod();
      </script>
   </body>
</html>

mixin에는 helloworld 및 samemethod 함수가 정의 된 메소드 속성이 있습니다. 마찬가지로 vue 인스턴스에는 두 개의 메서드가 start 및 samemethod로 다시 정의되는 methods 속성이 있습니다.

다음의 각 메소드가 호출됩니다.

vm.hellworld(); // In HelloWorld
vm.start(); // start method
vm.samemethod(); // Main: same method

위와 같이 helloworld, start, samemethod 함수를 호출했습니다. samemethod는 mixin에도 있지만 다음 콘솔에서 볼 수 있듯이 기본 인스턴스에 우선 순위가 부여됩니다.