VueJS-구성 요소

Vue Components HTML에서 재사용 할 수있는 사용자 지정 요소를 만드는 VueJS의 중요한 기능 중 하나입니다.

예제로 작업하고 구성 요소를 만들어 보겠습니다. 그러면 구성 요소가 VueJS와 함께 작동하는 방식을 더 잘 이해할 수 있습니다.

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "component_test">
         <testcomponent></testcomponent>
      </div>
      <div id = "component_test1">
         <testcomponent></testcomponent>
      </div>
      <script type = "text/javascript" src = "js/vue_component.js"></script>
   </body>
</html>

vue_component.js

Vue.component('testcomponent',{
   template : '<div><h1>This is coming from component</h1></div>'
});
var vm = new Vue({
   el: '#component_test'
});
var vm1 = new Vue({
   el: '#component_test1'
});

.html 파일에서 id를 가진 두 개의 div를 만들었습니다. component_testcomponent_test1. 에서.js위에 표시된 파일에서 두 개의 Vue 인스턴스가 div ID로 생성됩니다. 두 뷰 인스턴스와 함께 사용할 공통 구성 요소를 만들었습니다.

컴포넌트를 생성하기위한 구문은 다음과 같습니다.

Vue.component('nameofthecomponent',{ // options});

구성 요소가 생성되면 구성 요소의 이름이 사용자 정의 요소가되며 생성 된 Vue 인스턴스 요소 (예 : ID가있는 div 내부)에서 동일한 이름을 사용할 수 있습니다. component_testcomponent_test1.

에서 .js 파일에서 테스트 구성 요소를 구성 요소의 이름으로 사용했으며 div 내부의 사용자 지정 요소로 동일한 이름을 사용했습니다.

<div id = "component_test">
   <testcomponent></testcomponent>
</div>
<div id = "component_test1">
   <testcomponent></testcomponent>
</div>

생성 된 구성 요소에서 .js파일에 HTML 코드를 할당 한 템플릿을 추가했습니다. 이것은 방법입니다registering a global component다음 스크립트에 표시된대로 모든 vue 인스턴스의 일부가 될 수 있습니다.

Vue.component('testcomponent',{
   template : '<div><h1>This is coming from component</h1></div>'
});

실행시에도 동일한 내용이 브라우저에 반영됩니다.

구성 요소에는 사용자 정의 요소 태그가 제공됩니다. <testcomponent></testcomponent>. 그러나 브라우저에서 동일한 것을 검사 할 때 다음 스크린 샷에 표시된 것처럼 템플릿에있는 일반 HTML의 사용자 정의 태그를 알 수 없습니다.

다음 스크립트와 같이 구성 요소를 vue 인스턴스의 일부로 직접 만들었습니다.

var vm = new Vue({
   el: '#component_test',
   components:{
      'testcomponent': {
         template : '<div><h1>This is coming from component</h1></div>'
      }
   }
});

이것은 ... 불리운다 local registration 구성 요소는 생성 된 vue 인스턴스의 일부가됩니다.

지금까지 기본 옵션이있는 기본 구성 요소를 살펴 보았습니다. 이제 데이터 및 메서드와 같은 몇 가지 옵션을 추가해 보겠습니다. Vue 인스턴스에 데이터와 메서드가있는 것처럼 구성 요소도 동일합니다. 따라서 우리는 이미 데이터와 메소드로 본 코드를 확장 할 것입니다.

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "component_test">
         <testcomponent></testcomponent>
      </div>
      <div id = "component_test1">
         <testcomponent></testcomponent>
      </div>
      <script type = "text/javascript" src = "js/vue_component.js"></script>
   </body>
</html>

vue_component.js

Vue.component('testcomponent',{
   template : '<div v-on:mouseover = "changename()" v-on:mouseout = "originalname();"><h1>Custom Component created by <span id = "name">{{name}}</span></h1></div>',
   data: function() {
      return {
         name : "Ria"
      }
   },
   methods:{
      changename : function() {
         this.name = "Ben";
      },
      originalname: function() {
         this.name = "Ria";
      }
   }
});
var vm = new Vue({
   el: '#component_test'
});
var vm1 = new Vue({
   el: '#component_test1'
});

에서 .js위의 파일에서 객체를 반환하는 함수 인 데이터를 추가했습니다. 개체에는 'Ria'값이 할당 된 이름 속성이 있습니다. 다음 템플릿에서 사용됩니다.

template : '<div v-on:mouseover = "changename()" v-on:mouseout = "originalname();"><h1>Custom Component created by <span id = "name">{{name}}</span></h1></div>',

구성 요소에서 데이터를 함수로 가지고 있음에도 불구하고 직접 Vue 인스턴스에서 사용하는 것과 동일한 방식으로 속성을 사용할 수 있습니다. 또한 changename과 originalname이라는 두 가지 방법이 추가되었습니다. changename에서는 name 속성을 변경하고 originalname에서는 원래 이름으로 다시 설정합니다.

또한 div, mouseover 및 mouseout에 두 개의 이벤트를 추가했습니다. 이벤트에 대한 자세한 내용은 이벤트 장에서 논의됩니다. 그래서 지금은 mouseover가changename 메서드 및 마우스 아웃 호출 originalname 방법.

동일한 디스플레이가 다음 브라우저에 표시됩니다.

위의 브라우저에서 볼 수 있듯이 동일한 이름 인 데이터 속성에 할당 된 이름을 표시합니다. 또한 div에 mouseover 이벤트와 mouseout도 할당했습니다. mouseover와 mouseout이 어떻게되는지 봅시다.

마우스를 올리면 첫 번째 구성 요소의 이름이 Ben으로 변경되지만 두 번째 구성 요소는 그대로 유지됩니다. 이는 데이터 구성 요소가 함수이고 객체를 반환하기 때문입니다. 따라서 한 곳에서 변경 될 때 다른 경우에도 같은 내용을 덮어 쓰지 않습니다.

동적 구성 요소

동적 구성 요소는 키워드를 사용하여 생성됩니다. <component></component> 다음 예제와 같이 속성을 사용하여 바인딩됩니다.

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "databinding">
         <component v-bind:is = "view"></component>
      </div>
      <script type = "text/javascript">
         var vm = new Vue({
            el: '#databinding',
            data: {
               view: 'component1'
            },
            components: {
               'component1': {
                  template: '<div><span style = "font-size:25;color:red;">Dynamic Component</span></div>'
               }
            }
         });
      </script>
   </body>
</html>

산출

동적 구성 요소는 다음 구문을 사용하여 생성됩니다.

<component v-bind:is = "view"></component>

v-bind : is =”view”가 있으며 값보기가 할당됩니다. 뷰는 Vue 인스턴스에서 다음과 같이 정의됩니다.

var vm = new Vue({
   el: '#databinding',
   data: {
      view: 'component1'
   },
   components: {
      'component1': {
         template: '<div><span style = "font-size:25;color:red;">Dynamic Component</span></div>'
      }
   }
});

실행되면 템플릿 Dynamic Component 브라우저에가 표시됩니다.