v-text
v-text는 주로 JS의 text 속성과 동일할 수 있는 textContent를 업데이트하는 데 사용됩니다.
<span v-text="text"></span> // 等同于下方语句: <span>{{text}}</span>
v-html
이중 중괄호 방법은 데이터를 HTML이 아닌 일반 텍스트로 해석합니다. 실제 HTML을 출력하려면 v-html 명령을 사용할 수 있습니다. JS의 innerHtml 속성과 동일합니다.
참고: 콘텐츠는 일반 HTML로 삽입되며 Vue 템플릿으로 컴파일되지 않습니다.
<div v-html="html"></div>
v-show
은 CSS 표시 속성을 "없음" 및 "차단" 설정으로 전환하는 것과 동일합니다.
<div v-show="isShow">hello world</div>
v-if
v-if는 조건부 렌더링을 구현할 수 있습니다. Vue는 표현식 값의 true 및 false 조건을 기반으로 요소를 렌더링합니다.
<div v-show="isShow">hello world</div>
위 코드에서 isShow가 false이면 div가 렌더링되고, 그렇지 않으면 렌더링되지 않습니다.
참고:
v-if는 v-show와 구별되어야 합니다. v-show의 요소는 항상 DOM에 렌더링되고 저장됩니다. 단지 CSS의 표시 속성을 전환할 뿐입니다.
v-if의 스위칭 오버헤드가 더 높습니다.
v-show는 초기 렌더링 오버헤드가 더 높습니다.
그래서 매우 자주 전환하고 싶다면 v-show를 사용하는 것이 좋으며, 런타임 중에 조건이 변경될 가능성이 없다면 v-if를 사용하는 것이 좋습니다.
v-else
v-else는 v-if와 함께 사용되며 v-if 또는 v-else-if를 따라야 합니다. 그렇지 않으면 작동하지 않습니다.
JS의 if ..else와 유사합니다.
<div v-if="isSow">值为true的时候显示的内容</div> <div v-else>值为false的时候显示的内容</div>
v-else-if
v-else-if는 v-if의 else-if 블록 역할을 하며 체인에서 여러 번 사용될 수 있습니다. JS의 if .. else if .. else
<div v-if="type==='A'"> A </div> <div v-if="type==='B'"> B </div> <div v-if="type==='C'"> C </div> <div v-else> Not A,B,C </div>
v-for
와 유사하게 v-for 명령을 사용하여 배열을 순회하여 렌더링합니다.
<ul> <li v-for="item in items">{{item.name}}</li> </ul> <script> new Vue({ el: '#app', data: { items: [ { name: 'Runoob' }, { name: 'Google' }, { name: 'Taobao' } ] } }) </script> // 补充: // 也可以自行指定参数,最多可以接受3个参数 <div v-for="(item, index) in items"></div> <div v-for="(val, key) in object"></div> <div v-for="(val, name, index) in object"></div> // 迭代对象 <ul> <li v-for="value in object"> {{ index }}. {{ key }} : {{ value }} </li> // 迭代整数 <ul> <li v-for="n in 10"> {{ n }} </li> </ul>
v-on
이벤트 리스너를 바인딩하세요. 이벤트 유형은 매개변수로 지정됩니다. 표현식은 메소드 이름이거나 인라인 문일 수 있으며 수식자가 없으면 생략할 수 있습니다.
v-on은 다음과 같이 "@"로 축약될 수도 있습니다:
v-on="show"는 다음과 같이 축약될 수 있습니다: @show
<!-- 方法处理器 --> <button v-on:click="doThis"></button> <!-- 动态事件 (2.6.0+) --> <button v-on:[event]="doThis"></button> <!-- 内联语句 --> <button v-on:click="doThat('hello', $event)"></button> <!-- 缩写 --> <button @click="doThis"></button> <!-- 动态事件缩写 (2.6.0+) --> <button @[event]="doThis"></button> <!-- 停止冒泡 --> <button @click.stop="doThis"></button> <!-- 阻止默认行为 --> <button @click.prevent="doThis"></button> <!-- 阻止默认行为,没有表达式 --> <form @submit.prevent></form> <!-- 串联修饰符 --> <button @click.stop.prevent="doThis"></button> <!-- 键修饰符,键别名 --> <input @keyup.enter="onEnter"> <!-- 键修饰符,键代码 --> <input @keyup.13="onEnter"> <!-- 点击回调只会触发一次 --> <button v-on:click.once="doThis"></button> <!-- 对象语法 (2.4.0+) --> <button v-on="{ mousedown: doThis, mouseup: doThat }"></button>
다음과 같이 수정자를 사용할 수도 있습니다:
.stop - 호출 이벤트.stopPropagation().
.prevent - event.preventDefault()를 호출합니다.
.capture - 이벤트 리스너를 추가할 때 캡처 모드를 사용합니다.
.self - 콜백은 리스너가 바인딩된 요소 자체에서 이벤트가 트리거될 때만 트리거됩니다.
.{keyCode | keyAlias} - 특정 키에서 이벤트가 트리거될 때만 콜백을 실행합니다.
.native - 구성요소 루트 요소의 기본 이벤트를 수신합니다.
.once - 콜백을 한 번만 트리거합니다.
.left - 마우스 왼쪽 버튼을 클릭할 때만 트리거됩니다.
.right - 마우스 오른쪽 버튼을 클릭할 때만 트리거됩니다.
.middle - 마우스 가운데 버튼을 클릭할 때만 트리거됩니다.
.passive - { Passive: true } 모드에서 리스너를 추가합니다.
v-bind
하나 이상의 속성 또는 구성 요소 속성을 표현식에 동적으로 바인딩합니다. 클래스와 스타일을 동적으로 바인딩하는 데 자주 사용됩니다. 그리고 href 등.
는 다음과 같이 축약될 수 있습니다: " : "(예:
v-bind:class=" isActive : 'active' :' ' ", 다음과 같이 축약될 수 있음: :class=" isActive : 'active' :' ') "
<div v-bind:class=" isActive : 'active' :' ' "></div> <script> var app = new Vue({ el: '#app', data: { isActive : true, } }) </script> //渲染结果为: <div class="active"></div>
다음과 같이 여러 클래스를 바인딩합니다.
<div v-bind:class="[ isActive : 'active' :' ' , isError: 'error' :' ' ]"> </div> <script> var app = new Vue({ el: '#app', data: { isActive : true, isError: true, } }) </script> //渲染结果为: <div class="active error"></div>
다른 예의 경우 자세한 내용은 아래 코드를 참조하세요.
<!-- 绑定一个属性 --> <img v-bind:src="imageSrc"> <!-- 动态特性名 (2.6.0+) --> <button v-bind:[key]="value"></button> <!-- 缩写 --> <img :src="imageSrc"> <!-- 动态特性名缩写 (2.6.0+) --> <button :[key]="value"></button> <!-- 内联字符串拼接 --> <img :src="'/path/to/images/' + fileName"> <!-- class 绑定 --> <div :class="{ red: isRed }"></div> <div :class="[classA, classB]"></div> <div :class="[classA, { classB: isB, classC: isC }]"> <!-- style 绑定 --> <div :style="{ fontSize: size + 'px' }"></div> <div :style="[styleObjectA, styleObjectB]"></div> <!-- 绑定一个有属性的对象 --> <div v-bind="{ id: someProp, 'other-attr': otherProp }"></div> <!-- 通过 prop 修饰符绑定 DOM 属性 --> <div v-bind:text-content.prop="text"></div> <!-- prop 绑定。“prop”必须在 my-component 中声明。--> <my-component :prop="someThing"></my-component> <!-- 通过 $props 将父组件的 props 一起传给子组件 --> <child-component v-bind="$props"></child-component> <!-- XLink --> <svg><a :xlink:special="foo"></a></svg>
v-model
양식 컨트롤 또는 구성 요소에 양방향 바인딩을 만듭니다.
v-model은 모든 양식 요소의 value, selected 및 selected 속성의 초기 값을 무시합니다. Vue 인스턴스 데이터를 특정 값으로 선택하기 때문입니다.
<div id="app"> <input v-model="somebody"> <p>hello {{somebody}}</p> </div> <script> var app = new Vue({ el: '#app', data: { somebody:'小明' } }) </script>
이 예에서는 브라우저 입력에 직접 다른 이름을 입력하면 아래 p의 내용이 바로 변경됩니다. 이는 양방향 데이터 바인딩입니다.
사용 가능한 수정자:
.lazy - 기본적으로 v-model은 입력 상자의 값과 데이터를 동기화합니다. 이 수정자를 사용하여 변경 이벤트에서 재동기화로 전환할 수 있습니다.
.number - 사용자의 입력 값을 숫자 유형으로 자동 변환합니다.
.trim - 사용자가 입력한 앞뒤 공백을 자동으로 필터링합니다.
수정자 사용:
<input v-model.trim="somebody">
v-pre
v-pre는 주로 이 요소와 하위 요소의 컴파일 프로세스를 건너뛰는 데 사용됩니다. 원래 콧수염 태그를 표시하는 데 사용할 수 있습니다. 컴파일 속도를 높이기 위해 지침 없이 많은 수의 노드를 건너뜁니다.
<div id="app"> <span v-pre>{{message}}</span> //这条语句不进行编译 <span>{{message}}</span> </div>
이 지시문은 컴파일을 위해 연결된 인스턴스가 끝날 때까지 요소에 유지되는 데 사용됩니다.
<div id="app" v-cloak> <div> {{message}} </div> </div> <script type="text/javascript"> new Vue({ el:'#app', data:{ message:'hello world' } }) </script>
설명:
페이지가 로드되면 깜박입니다. 먼저
<div> {{message}} </div>
가 표시되고 다음과 같이 컴파일됩니다.
<div> hello world! </div>
v-cloak 명령은 다음과 같이 위의 보간 깜박임 문제를 해결할 수 있습니다. 사용되는 것은 보간이 로드되지 않은 경우 스타일 속성을 통해 콘텐츠가 숨겨지는 것입니다.
<style> [v-cloak] { display: none; } </style> <div id="app"> <!-- 使用 v-cloak 能够解决 插值表达式闪烁的问题 --> <p v-cloak>++++++++ {{ msg }} ----------</p> </div> <script> var vm = new Vue({ el: '#app', data: { msg: 'hello', } }) </script>
v-once
v-once关联的实例,只会渲染一次。之后的重新渲染,实例极其所有的子节点将被视为静态内容跳过,这可以用于优化更新性能。
<span v-once>This will never change:{{msg}}</span> //单个元素 <div v-once>//有子元素 <h1>comment</h1> <p>{{msg}}</p> </div> <my-component v-once:comment="msg"></my-component> //组件 <ul> <li v-for="i in list">{{i}}</li> </ul>
上面的例子中,msg,list即使产生改变,也不会重新渲染。
v-slot
提供具名插槽或需要接收 prop 的插槽。
可简写为:#
slot 和 scope-slot 是在 vue@2.6.x 之前的语法,而从 vue@2.6.0 开始,官方推荐我们使用 v-slot 来替代前两者。
使用具名插槽来自定义模板内容(vue@2.6.x已经废弃)
<div class="container"> <header> <slot name="header"></slot> </header> <main> <slot></slot> </main> <footer> <slot name="footer"></slot> </footer> </div>
在向具名插槽提供内容的时候,我们可以在一个父组件的 元素上使用 slot 特性:
<base-layout> <template slot="header"> <h1>Here might be a page title</h1> </template> <p>A paragraph for the main content.</p> <p>And another one.</p> <template slot="footer"> <p>Here's some contact info</p> </template> </base-layout>
接下来,使用 v-slot 指令改写上面的栗子:
<base-layout> <template v-slot:header> <h1>Here might be a page title</h1> </template> <p>A paragraph for the main content.</p> <p>And another one.</p> <template v-slot:footer> <p>Here's some contact info</p> </template> </base-layout>
使用 # 简写代替 v-slot
<base-layout> <template #header> <h1>Here might be a page title</h1> </template> <p>A paragraph for the main content.</p> <p>And another one.</p> <template #footer> <p>Here's some contact info</p> </template> </base-layout>
相关推荐:
更多编程相关知识,请访问:编程教学!!
위 내용은 vue.js의 일반적인 지침 이해(요약)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!