VueJS-바인딩
이 장에서는 HTML 속성에 값을 조작하거나 할당하고, 스타일을 변경하고, 바인딩 지시문을 사용하여 클래스를 할당하는 방법을 배웁니다. v-bind VueJS에서 사용할 수 있습니다.
데이터 바인딩에 v-bind 지시문이 필요한 이유와 사용시기를 이해하기위한 예제를 고려해 보겠습니다.
예
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<div id = "databinding">
{{title}}<br/>
<a href = "hreflink" target = "_blank"> Click Me </a> <br/>
<a href = "{{hreflink}}" target = "_blank">Click Me </a> <br/>
<a v-bind:href = "hreflink" target = "_blank">Click Me </a> <br/>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#databinding',
data: {
title : "DATA BINDING",
hreflink : "http://www.google.com"
}
});
</script>
</body>
</html>
위의 예에서는 제목 변수와 세 개의 앵커 링크를 표시했습니다. 또한 데이터 개체의 href에 값을 할당했습니다.
이제 브라우저에서 출력을 확인하고 검사하면 다음 스크린 샷과 같이 처음 두 개의 앵커 링크에 href가 올바르게 포함되지 않은 것을 볼 수 있습니다.
첫 번째 클릭은 href를 hreflink로 표시하고 두 번째 클릭은 {{hreflink}}에 표시하고 마지막 클릭은 필요한대로 올바른 URL을 표시합니다.
따라서 HTML 속성에 값을 할당하려면 다음과 같이 v-bind 지시문으로 바인딩해야합니다.
<a v-bind:href = "hreflink" target = "_blank">Click Me </a>
VueJS는 다음과 같이 v-bind에 대한 속기를 제공합니다.
<a :href = "hreflink" target = "_blank">Click Me </a>
브라우저에서 inspect 요소를 보면 앵커 태그는 v-bind 속성을 표시하지 않지만 일반 HTML을 표시합니다. DOM을 검사 할 때 VueJS 속성이 표시되지 않습니다.
HTML 클래스 바인딩
HTML 클래스를 바인딩하려면 다음을 사용해야합니다. v-bind: class. 예제를 고려하고 그 안에 클래스를 바인딩 해 봅시다.
예
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<style>
.active {
background: red;
}
</style>
<div id = "classbinding">
<div v-bind:class = "{active:isactive}"><b>{{title}}</b></div>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#classbinding',
data: {
title : "CLASS BINDING",
isactive : true
}
});
</script>
</body>
</html>
v-bind : class =”{active : isactive}”로 생성 된 div가 있습니다.
여기, isactive참 또는 거짓을 기반으로하는 변수입니다. 활성 클래스를 div에 적용합니다. 데이터 개체에서 isactive 변수를 true로 할당했습니다. 스타일에 정의 된 클래스가 있습니다..active 배경색은 빨간색입니다.
변수 isactive가 true이면 색상이 적용되지 않습니다. 다음은 브라우저의 출력입니다.
위 화면에서 배경색이 빨간색임을 알 수 있습니다. class =”active”가 div에 적용됩니다.
이제 변수 값을 false로 변경하고 출력을 보겠습니다. isactive 변수는 다음 코드와 같이 false로 변경됩니다.
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<style>
.active {
background: red;
}
</style>
<div id = "classbinding">
<div v-bind:class = "{active:isactive}"><b>{{title}}</b></div>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#classbinding',
data: {
title : "CLASS BINDING",
isactive : false
}
});
</script>
</body>
</html>
위의 디스플레이에서 활성 클래스가 div에 적용되지 않은 것을 볼 수 있습니다.
v-bind 속성을 사용하여 HTML 태그에 여러 클래스를 할당 할 수도 있습니다.
예
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<style>
.info {
color: #00529B;
background-color: #BDE5F8;
}
div {
margin: 10px 0;
padding: 12px;
}
.active {
color: #4F8A10;
background-color: #DFF2BF;
}
.displayError{
color: #D8000C;
background-color: #FFBABA;
}
</style>
<div id = "classbinding">
<div class = "info" v-bind:class = "{ active: isActive, 'displayError': hasError }">
{{title}}
</div>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#classbinding',
data: {
title : "This is class binding example",
isActive : false,
hasError : false
}
});
</script>
</body>
</html>
위 코드의 div에는 일반 클래스 (예 : class =”info”)를 적용했습니다. isActive 및 hasError 변수를 기반으로 다른 클래스가 div에 적용됩니다.
산출
적용되는 일반 클래스입니다. 지금은 두 변수 모두 거짓입니다. 만들자isActive 변수를 true로 설정하고 출력을 확인하십시오.
위의 디스플레이에서 DOM에서 div, info 및 active에 할당 된 두 개의 클래스를 볼 수 있습니다. hasError 변수를 true로 만들고 isActive를 false로 만들어 봅시다.
이제 위의 디스플레이에서 볼 때 info 및 displayError 클래스가 div에 적용됩니다. 이것이 조건에 따라 여러 클래스를 적용 할 수있는 방법입니다.
클래스를 배열로 전달할 수도 있습니다. 이것을 이해하기 위해 예를 들어 보겠습니다.
예
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<style>
.info {
color: #00529B;
background-color: #BDE5F8;
}
div {
margin: 10px 0;
padding: 12px;
font-size : 25px;
}
.active {
color: #4F8A10;
background-color: #DFF2BF;
}
.displayError{
color: #D8000C;
background-color: #FFBABA;
}
</style>
<div id = "classbinding">
<div v-bind:class = "[infoclass, errorclass]">{{title}}</div>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#classbinding',
data: {
title : "This is class binding example",
infoclass : 'info',
errorclass : 'displayError'
}
});
</script>
</body>
</html>
산출
위에서 볼 수 있듯이 두 클래스 모두 div에 적용됩니다. 변수를 사용하고 변수의 값에 따라 클래스를 할당 해 보겠습니다.
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<style>
.info {
color: #00529B;
background-color: #BDE5F8;
}
div {
margin: 10px 0;
padding: 12px;
font-size : 25px;
}
.active {
color: #4F8A10;
background-color: #DFF2BF;
}
.displayError{
color: #D8000C;
background-color: #FFBABA;
}
</style>
<div id = "classbinding">
<div v-bind:class = "[isActive ? infoclass : '', haserror ? errorclass : '']">{{title}}</div>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#classbinding',
data: {
title : "This is class binding example",
infoclass : 'info',
errorclass : 'displayError',
isActive : true,
haserror : false
}
});
</script>
</body>
</html>
두 개의 변수를 사용했습니다. isActive 과 haserror 다음 div 태그와 같이 클래스 바인딩 동안 div에도 동일하게 사용됩니다.
<div v-bind:class = "[isActive ? infoclass : '', haserror ? errorclass : '']">{{title}}</div>
isActive가 true이면 infoclass가 할당됩니다. haserror도 마찬가지입니다. 참이면 errorClass 만 적용됩니다.
이제 haserror 변수를 true로, isActive 변수를 false로 설정하겠습니다.
이제 컴포넌트의 클래스에 대해 v-bind를 추가합니다. 다음 예제에서는 구성 요소 템플릿과 구성 요소에도 클래스를 추가했습니다.
예
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<style>
.info {
color: #00529B;
background-color: #BDE5F8;
}
div {
margin: 10px 0;
padding: 12px;
font-size : 25px;
}
.active {
color: #4F8A10;
background-color: #DFF2BF;
}
.displayError{
color: #D8000C;
background-color: #FFBABA;
}
</style>
<div id = "classbinding">
<new_component class = "active"></new_component>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#classbinding',
data: {
title : "This is class binding example",
infoclass : 'info',
errorclass : 'displayError',
isActive : false,
haserror : true
},
components:{
'new_component' : {
template : '<div class = "info">Class Binding for component</div>'
}
}
});
</script>
</body>
</html>
다음은 브라우저의 출력입니다. 두 클래스 모두 최종 div에 적용됩니다.
<div class = ”info active”></div>
true / false에 따라 표시 할 구성 요소 섹션에 변수를 추가하십시오.
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<style>
.info {
color: #00529B;
background-color: #BDE5F8;
}
div {
margin: 10px 0;
padding: 12px;
font-size : 25px;
}
.active {
color: #4F8A10;
background-color: #DFF2BF;
}
.displayError{
color: #D8000C;
background-color: #FFBABA;
}
</style>
<div id = "classbinding">
<new_component v-bind:class = "{active:isActive}"></new_component>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#classbinding',
data: {
title : "This is class binding example",
infoclass : 'info',
errorclass : 'displayError',
isActive : false,
haserror : true
},
components:{
'new_component' : {
template : '<div class = "info">Class Binding for component</div>'
}
}
});
</script>
</body>
</html>
변수가 false이므로 다음 스크린 샷과 같이 활성 클래스가 적용되지 않고 info 클래스가 적용됩니다.
인라인 스타일 바인딩
개체 구문
Example
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<div id = "databinding">
<div v-bind:style = "{ color: activeColor, fontSize: fontSize + 'px' }">{{title}}</div>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#databinding',
data: {
title : "Inline style Binding",
activeColor: 'red',
fontSize :'30'
}
});
</script>
</body>
</html>
Output
위의 예에서 div의 경우 스타일이 적용되고 데이터 개체에서 데이터를 가져옵니다.
<div v-bind:style = "{ color: activeColor, fontSize: fontSize + 'px' }">{{title}}</div>
data: {
title : "Inline style Binding",
activeColor: 'red',
fontSize :'30'
}
모든 값을 변수에 할당 한 다음 변수를 div에 할당하여 동일한 작업을 수행 할 수도 있습니다.
Example
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<div id = "databinding">
<div v-bind:style = "styleobj">{{title}}</div>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#databinding',
data: {
title : "Inline style Binding",
styleobj : {
color: 'red',
fontSize :'40px'
}
}
});
</script>
</body>
</html>
색상과 fontSize는 styleobj라는 객체에 할당되고 동일한 값이 div에 할당됩니다.
<div v-bind:style = "styleobj">{{title}}</div>
Output
양식 입력 바인딩
지금까지 생성 한 예제에서 입력 텍스트 요소를 바인딩하는 v-model과 할당 된 변수에 바인딩 된 값을 보았습니다. 이 섹션에서 이에 대해 자세히 알아 보겠습니다.
예
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<div id = "databinding">
<h3>TEXTBOX</h3>
<input v-model = "name" placeholder = "Enter Name" />
<h3>Name entered is : {{name}}</h3>
<hr/>
<h3>Textarea</h3>
<textarea v-model = "textmessage" placeholder = "Add Details"></textarea>
<h1><p>{{textmessage}}</p></h1>
<hr/>
<h3>Checkbox</h3>
<input type = "checkbox" id = "checkbox" v-model = "checked"> {{checked}}
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#databinding',
data: {
name:'',
textmessage:'',
checked : false
}
});
</script>
</body>
</html>
texbox에 입력하는 내용이 아래에 표시됩니다. v-model에는 값 이름이 할당되고 이름은 {{name}}에 표시되며 텍스트 상자에 입력 된 내용을 모두 표시합니다.
산출
더 많은 예제와 사용 방법을 살펴 보겠습니다.
라디오 및 선택
Example
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<div id = "databinding">
<h3>Radio</h3>
<input type = "radio" id = "black" value = "Black" v-model = "picked">Black
<input type = "radio" id = "white" value = "White" v-model = "picked">White
<h3>Radio element clicked : {{picked}} </h3>
<hr/>
<h3>Select</h3>
<select v-model = "languages">
<option disabled value = "">Please select one</option>
<option>Java</option>
<option>Javascript</option>
<option>Php</option>
<option>C</option>
<option>C++</option>
</select>
<h3>Languages Selected is : {{ languages }}</h3>
<hr/>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#databinding',
data: {
picked : 'White',
languages : "Java"
}
});
</script>
</body>
</html>
Output
수정 자
예제에서는 trim, number 및 lazy의 세 가지 수정자를 사용했습니다.
Example
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<div id = "databinding">
<span style = "font-size:25px;">Enter Age:</span> <input v-model.number = "age" type = "number">
<br/>
<span style = "font-size:25px;">Enter Message:</span> <input v-model.lazy = "msg">
<h3>Display Message : {{msg}}</h3>
<br/>
<span style = "font-size:25px;">Enter Message : </span><input v-model.trim = "message">
<h3>Display Message : {{message}}</h3>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#databinding',
data: {
age : 0,
msg: '',
message : ''
}
});
</script>
</body>
</html>
Output
Number modifier숫자 만 입력 할 수 있습니다. 숫자 외에 다른 입력을받지 않습니다.
<span style = "font-size:25px;">Enter Age:</span> <input v-model.number = "age" type = "number">
Lazy modifier 텍스트 상자가 완전히 입력되고 사용자가 텍스트 상자에서 나가면 텍스트 상자에있는 콘텐츠가 표시됩니다.
<span style = "font-size:25px;">Enter Message:</span> <input v-model.lazy = "msg">
Trim modifier 시작과 끝에 입력 된 모든 공백을 제거합니다.
<span style = "font-size:25px;">Enter Message : </span><input v-model.trim = "message">