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>

두 개의 변수를 사용했습니다. isActivehaserror 다음 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">