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에도 있지만 다음 콘솔에서 볼 수 있듯이 기본 인스턴스에 우선 순위가 부여됩니다.