Vue에서 일반적으로 사용되는 내장 명령어에 대해 이야기하는 기사 [백과사전]
이 글은 Vue에 내장된 모든 지침을 검토하고 요약합니다. 몇 가지 일반적인 지침을 먼저 설명하고 덜 일반적으로 사용되는 지침은 뒤에 배치합니다.
0. 보간 표현식
설명 : 보간 표현식은 Mustache 구문(예: 이중 중괄호)이라고도 하며 이중 중괄호 레이블은 해당 구성 요소 인스턴스 로 대체됩니다. msg
속성. 동시에 msg
속성이 변경될 때마다 동기적으로 업데이트됩니다. [관련 권장사항: vuejs 비디오 튜토리얼msg
属性的值。同时每次 msg
属性更改时它也会同步更新。【相关推荐:vuejs视频教程】
<template id="my-app"> <!-- 1.mustache的基本使用 --> <h2>{{message}} - {{message}}</h2> <!-- 2.是一个表达式 --> <h2>{{counter * 10}}</h2> <h2>{{ message.split(" ").reverse().join(" ") }}</h2> <!-- 3.也可以调用函数 --> <!-- 可以使用computed(计算属性) --> <h2>{{getReverseMessage()}}</h2> <!-- 4.三元运算符 --> <h2>{{ isShow ? "哈哈哈": "" }}</h2> <button @click="toggle">切换</button> <!-- 错误用法 --> <!-- var name = "abc" -> 赋值语句 --> <!-- <h2>{{var name = "abc"}}</h2> <h2>{{ if(isShow) { return "哈哈哈" } }}</h2> --> </template>
1. v-on
说明: 给元素绑定事件监听器。
缩写:@
参数: event
(使用对象语法则为可选项)
修饰符:
-
.stop
——调用event.stopPropagation()
。 -
.prevent
——调用event.preventDefault()
。 -
.capture
——在捕获模式添加事件监听器。 -
.self
——只有事件从元素本身发出才触发处理函数。 -
.{keyAlias}
——只在某些按键下触发处理函数。 -
.once
——最多触发一次处理函数。 -
.left
——只在鼠标左键事件触发处理函数。 -
.right
——只在鼠标右键事件触发处理函数。 -
.middle
——只在鼠标中键事件触发处理函数。 -
.passive
——通过{ passive: true }
附加一个 DOM 事件。
详细描述:事件类型由参数来指定。表达式可以是一个方法名,一个内联声明,如果有修饰符则可省略。
- 当用于普通元素,只监听原生 DOM 事件。当用于自定义元素组件,则监听子组件触发的自定义事件。
- 当监听原生 DOM 事件时,方法接收原生事件作为唯一参数。如果使用内联声明,声明可以访问一个特殊的
$event
变量:v-on:click="handle('ok', $event)"
。 -
v-on
还支持绑定不带参数的事件/监听器对的对象。请注意,当使用对象语法时,不支持任何修饰符。
<!-- 方法处理函数 --> <button v-on:click="doThis"></button> <!-- 动态事件 --> <button v-on:[event]="doThis"></button> <!-- 内联声明 --> <button v-on:click="doThat('hello', $event)"></button> <!-- 缩写 --> <button @click="doThis"></button> <!-- 使用缩写的动态事件 --> <button @[event]="doThis"></button> <!-- 停止传播 --> <button @click.stop="doThis"></button> <!-- 阻止默认事件 --> <button @click.prevent="doThis"></button> <!-- 不带表达式地阻止默认事件 --> <form @submit.prevent></form> <!-- 链式调用修饰符 --> <button @click.stop.prevent="doThis"></button> <!-- 按键用于 keyAlias 修饰符--> <input @keyup.enter="onEnter" /> <!-- 点击事件将最多触发一次 --> <button v-on:click.once="doThis"></button> <!-- 对象语法 --> <button v-on="{ mousedown: doThis, mouseup: doThat }"></button>
说明: 动态的绑定一个或多个 attribute,也可以是组件的 prop。
缩写: :
或者 .
(当使用 .prop
修饰符)
修饰符:
.camel
——将短横线命名的 attribute 转变为驼峰式命名。.prop
——强制绑定为 DOM property。3.2+.attr
——强制绑定为 DOM attribute。3.2+
用途:
- 当用于绑定
class
或style
attribute,v-bind
支持额外的值类型如数组或对象。详见下方的指南链接。 - 在处理绑定时,Vue 默认会利用
in
操作符来检查该元素上是否定义了和绑定的 key 同名的 DOM property。如果存在同名的 property,则 Vue 会把作为 DOM property 赋值,而不是作为 attribute 设置。这个行为在大多数情况都符合期望的绑定值类型,但是你也可以显式用.prop
和.attr
]1.v-on<!-- 绑定 attribute --> <img v-bind:src="imageSrc" /> <!-- 动态 attribute 名 --> <button v-bind:[key]="value"></button> <!-- 缩写 --> <img :src="imageSrc" /> <!-- 缩写形式的动态 attribute 名 --> <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 }]"></div> <!-- style 绑定 --> <div :style="{ fontSize: size + 'px' }"></div> <div :style="[styleObjectA, styleObjectB]"></div> <!-- 绑定对象形式的 attribute --> <div v-bind="{ id: someProp, 'other-attr': otherProp }"></div> <!-- prop 绑定。“prop” 必须在子组件中已声明。 --> <MyComponent :prop="someThing" /> <!-- 传递子父组件共有的 prop --> <MyComponent v-bind="$props" /> <!-- XLink --> <svg><a :xlink:special="foo"></a></svg>
로그인 후 복사 - 설명: 이벤트 리스너를 요소에 바인딩합니다.
약어: @
매개변수: event
(객체 구문 사용 시 선택 사항)
- 🎜
<template>
- components (用于带有 prop 的单个默认插槽)
- 当使用直接在 DOM 中书写的模板时,可能会出现一种叫做“未编译模板闪现”的情况:用户可能先看到的是还没编译完成的双大括号标签,直到挂载的组件将它们替换为实际渲染的内容。
v-cloak
会保留在所绑定的元素上,直到相关组件实例被挂载后才移除。配合像[v-cloak] { display: none }
这样的 CSS 规则,它可以在组件编译完毕前隐藏原始模板。
.stop</code >—— <code>event.stopPropagation()
을 호출하세요. 🎜🎜.prevent
- event.preventDefault()
를 호출합니다. 🎜🎜.capture
- 캡처 모드에서 이벤트 리스너를 추가합니다. 🎜🎜.self
- 핸들러 함수는 요소 자체에서 이벤트가 발생하는 경우에만 트리거됩니다. 🎜🎜.{keyAlias}
- 특정 키에서만 처리 기능을 트리거합니다. 🎜🎜.once
- 처리 기능을 최대 한 번 트리거합니다. 🎜🎜.left
- 왼쪽 마우스 버튼 이벤트에서만 핸들러 기능을 트리거합니다. 🎜🎜.right
- 마우스 오른쪽 버튼 이벤트에서만 핸들러 기능을 트리거합니다. 🎜🎜.middle
- 마우스 가운데 버튼 이벤트에서만 핸들러 기능을 트리거합니다. 🎜🎜.passive
- { Passive: true }
를 통해 DOM 이벤트를 연결합니다. 🎜🎜🎜🎜🎜🎜상세 설명: 🎜이벤트 유형은 매개변수로 지정됩니다. 표현식은 메소드 이름, 인라인 선언일 수 있으며 수정자가 있는 경우 생략될 수 있습니다. 🎜- 🎜일반 요소에 사용되는 경우 🎜네이티브 DOM 이벤트🎜🎜. 맞춤 요소 구성 요소에 사용되는 경우 하위 구성 요소에 의해 트리거되는 🎜맞춤 이벤트🎜를 수신합니다. 🎜🎜네이티브 DOM 이벤트를 수신할 때 메서드는 네이티브 이벤트를 유일한 매개변수로 받습니다. 인라인 선언이 사용되는 경우 선언은 특수
$event
변수(v-on:click="handle('ok', $event)"
)에 액세스할 수 있습니다. 🎜🎜v-on
은 매개변수 없이 이벤트/리스너 쌍의 바인딩 개체도 지원합니다. 객체 구문을 사용할 때는 수정자가 지원되지 않습니다. 🎜🎜<h2 v-if="isShow">哈哈哈哈</h2>
🎜🎜🎜설명: 🎜 구성 요소의 소품일 수도 있는 하나 이상의 속성을 동적으로 바인딩합니다. 🎜🎜🎜약어: 🎜 :
또는 .
(.prop
수정자를 사용하는 경우) 🎜🎜🎜수정자: 🎜🎜 🎜 .camel
- 대시로 명명된 속성을 낙타 케이스 명명으로 변환합니다. 🎜🎜.prop
- DOM 속성에 강제 바인딩합니다. 3.2+🎜🎜.attr
- DOM 속성에 강제 바인딩합니다. 3.2+🎜🎜🎜🎜사용법: 🎜🎜🎜class
또는 style
속성을 바인딩하는 데 사용되는 경우 v-bind
는 추가 값을 지원합니다. 배열이나 객체와 같은 유형입니다. 자세한 내용은 아래 가이드 링크를 참조하세요. 🎜🎜바인딩을 처리할 때 Vue는 기본적으로 in
연산자를 사용하여 바인딩된 키와 동일한 이름을 가진 DOM 속성이 요소에 정의되어 있는지 확인합니다. 동일한 이름의 속성이 존재하는 경우 Vue는 이를 속성으로 설정하는 대신 DOM 속성으로 할당합니다. 이 동작은 대부분의 경우 예상되는 바인딩 값 유형과 일치하지만 .prop
및 .attr
수정자를 사용하여 명시적으로 바인딩을 강제할 수도 있습니다. 때로는 이것이 필요한데, 특히 🎜Custom Elements🎜를 다룰 때 그렇습니다. 🎜🎜컴포넌트 소품 바인딩에 사용되는 경우 바인딩된 소품은 하위 구성 요소에서 올바르게 선언되어야 합니다. 🎜🎜매개변수 없이 사용하면 여러 속성 이름 바인딩 값 쌍을 포함하는 개체를 바인딩하는 데 사용할 수 있습니다. 🎜🎜<h2 v-if="isShow">Coder</h2>
<h2 v-else>Bin</h2>
로그인 후 복사로그인 후 복사🎜🎜3. v-if🎜🎜🎜🎜 설명: 🎜 표현 값의 참 또는 거짓을 기반으로 요소 또는 템플릿 조각을 조건부로 렌더링합니다. 🎜<h2 v-if="isShow">哈哈哈哈</h2>
로그인 후 복사로그인 후 복사4. v-else
说明: 表示 v-if
或 v-if
/ v-else-if
链式调用的“else 块”。
<h2 v-if="isShow">Coder</h2>
<h2 v-else>Bin</h2>
로그인 후 복사로그인 후 복사ishow 为 true 显示 Coder,反之显示 Bin
5. v-else-if
说明: 表示 v-if
的“else if 块”。可以进行链式调用。
<template id="my-app">
<input type="text" v-model="score">
<h2 v-if="score > 90">优秀</h2>
<h2 v-else-if="score > 60">良好</h2>
<h2 v-else>不及格</h2>
</template>
로그인 후 복사v-model 后面会说明
6. v-show
说明:基于表达式值的真假性,来改变元素的可见性。
详细描述:v-show
通过设置内联样式的 display
CSS 属性来工作,当元素可见时将使用初始 display
值。当条件改变时,也会触发过渡效果。
<template id="my-app">
<h2 v-show="isShow">哈哈哈哈</h2>
</template>
<script>
const App = {
template: '#my-app',
data() {
return {
isShow: true
}
}
}
Vue.createApp(App).mount('#app');
</script>
로그인 후 복사v-show
不支持在 <template>
元素上使用,也不能和 v-else
搭配使用。
7. v-model
说明: 在表单输入元素或组件上创建双向绑定。
仅限: <input>
、<select>
、 <textarea>
、components
修饰符:
基本使用:
<template id="my-app">
<!-- 1.v-bind value的绑定 2.监听input事件, 更新message的值 -->
<!-- <input type="text" :value="message" @input="inputChange"> -->
<input type="text" v-model="message">
<h2>{{message}}</h2>
</template>
<script>
const App = {
template: '#my-app',
data() {
return {
message: "Hello World"
}
},
methods: {
inputChange(event) {
this.message = event.target.value;
}
}
}
Vue.createApp(App).mount('#app');
로그인 후 복사绑定其他表单:
<template id="my-app">
<!-- 1.绑定textarea -->
<label for="intro">
自我介绍
<textarea name="intro" id="intro" cols="30" rows="10" v-model="intro"></textarea>
</label>
<h2>intro: {{intro}}</h2>
<!-- 2.checkbox -->
<!-- 2.1.单选框 -->
<label for="agree">
<input id="agree" type="checkbox" v-model="isAgree"> 同意协议
</label>
<h2>isAgree: {{isAgree}}</h2>
<!-- 2.2.多选框 -->
<span>你的爱好: </span>
<label for="basketball">
<input id="basketball" type="checkbox" v-model="hobbies" value="basketball"> 篮球
</label>
<label for="football">
<input id="football" type="checkbox" v-model="hobbies" value="football"> 足球
</label>
<label for="tennis">
<input id="tennis" type="checkbox" v-model="hobbies" value="tennis"> 网球
</label>
<h2>hobbies: {{hobbies}}</h2>
<!-- 3.radio -->
<span>你的爱好: </span>
<label for="male">
<input id="male" type="radio" v-model="gender" value="male">男
</label>
<label for="female">
<input id="female" type="radio" v-model="gender" value="female">女
</label>
<h2>gender: {{gender}}</h2>
<!-- 4.select -->
<span>喜欢的水果: </span>
<select v-model="fruit" multiple size="2">
<option value="apple">苹果</option>
<option value="orange">橘子</option>
<option value="banana">香蕉</option>
</select>
<h2>fruit: {{fruit}}</h2>
</template>
<script>
const App = {
template: '#my-app',
data() {
return {
intro: "Hello World",
isAgree: false,
hobbies: ["basketball"],
gender: "",
fruit: "orange"
}
},
methods: {
commitForm() {
axios
}
}
}
Vue.createApp(App).mount('#app');
</script>
로그인 후 복사v-model修饰符的使用
<template id="my-app">
<!-- 1.lazy修饰符 -->
<!-- <input type="text" v-model.lazy="message"> -->
<!-- 2.number修饰符 -->
<!-- <input type="text" v-model.number="message">
<h2>{{message}}</h2>
<button @click="showType">查看类型</button> -->
<!-- 3.trim修饰符 -->
<input type="text" v-model.trim="message">
<button @click="showResult">查看结果</button>
</template>
<script>
const App = {
template: '#my-app',
data() {
return {
message: "Hello World"
}
},
methods: {
showType() {
console.log(this.message, typeof this.message);
},
showResult() {
console.log(this.message);
}
}
}
Vue.createApp(App).mount('#app');
</script>
로그인 후 복사8. v-for
说明: 基于原始数据多次渲染元素或模板块。
详细描述:
指令值必须使用特殊语法 alias in expression
为正在迭代的元素提供一个别名:
<div v-for="item in items">
{{ item.text }}
</div>
로그인 후 복사或者,你也可以为索引指定别名 (如果用在对象,则是键值):
<div v-for="(item, index) in items"></div>
<div v-for="(value, key) in object"></div>
<div v-for="(value, name, index) in object"></div>
로그인 후 복사v-for
的默认方式是尝试就地更新元素而不移动它们。要强制其重新排序元素,你需要用特殊 attribute key
来提供一个排序提示:
<div v-for="item in items" :key="item.id">
{{ item.text }}
</div>
로그인 후 복사9. v-slot
说明: 用于声明具名插槽或是期望接收 props 的作用域插槽。
缩写: #
参数:插槽名 (可选,默认是 default
)
仅限:
示例
<!-- 具名插槽 -->
<BaseLayout>
<template v-slot:header>
Header content
</template>
<template v-slot:default>
Default slot content
</template>
<template v-slot:footer>
Footer content
</template>
</BaseLayout>
<!-- 接收 prop 的具名插槽 -->
<InfiniteScroll>
<template v-slot:item="slotProps">
<div class="item">
{{ slotProps.item.text }}
</div>
</template>
</InfiniteScroll>
<!-- 接收 prop 的默认插槽,并解构 -->
<Mouse v-slot="{ x, y }">
Mouse position: {{ x }}, {{ y }}
</Mouse>
로그인 후 복사10. v-text
说明: 更新元素的文本内容。
详细描述: v-text
通过设置元素的 textContent 属性来工作,因此它将覆盖元素中所有现有的内容。如果你需要更新 textContent
的部分,应该使用 mustache interpolations 代替。
<span v-text="msg"></span>
<!-- 等同于 -->
<span>{{msg}}</span>
로그인 후 복사11. v-html
说明: 更新元素的 innerHTML。
详细描述: v-html
的内容直接作为普通 HTML 插入—— Vue 模板语法是不会被解析的。如果你发现自己正打算用 v-html
来编写模板,不如重新想想怎么使用组件来代替。
安全说明:
在你的站点上动态渲染任意的 HTML 是非常危险的,因为它很容易导致 XSS 攻击。请只对可信内容使用 HTML 插值,绝不要将用户提供的内容作为插值
<div v-html="html"></div>
로그인 후 복사12. v-pre
说明: 跳过该元素及其所有子元素的编译。
详细描述:元素内具有 v-pre
,所有 Vue 模板语法都会被保留并按原样渲染。最常见的用例就是显示原始双大括号标签及内容。
<span v-pre>{{ this will not be compiled }}</span>
로그인 후 복사13. v-once
说明: 跳过该元素及其所有子元素的编译。
详细描述: 在随后的重新渲染,元素/组件及其所有子项将被当作静态内容并跳过渲染。这可以用来优化更新时的性能。
<!-- 单个元素 -->
<span v-once>This will never change: {{msg}}</span>
<!-- 带有子元素的元素 -->
<div v-once>
<h1>comment</h1>
<p>{{msg}}</p>
</div>
<!-- 组件 -->
<MyComponent v-once :comment="msg" />
<!-- `v-for` 指令 -->
<ul>
<li v-for="i in list" v-once>{{i}}</li>
</ul>
로그인 후 복사14. v-cloak
说明: 用于隐藏尚未完成编译的 DOM 模板。
详细描述:该指令只在没有构建步骤的环境下需要使用。
[v-cloak] {
display: none;
}
로그인 후 복사<div v-cloak>
{{ message }}
</div>
로그인 후 복사更多编程相关知识,请访问:编程入门!!
위 내용은 Vue에서 일반적으로 사용되는 내장 명령어에 대해 이야기하는 기사 [백과사전]의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!
.camel
- 대시로 명명된 속성을 낙타 케이스 명명으로 변환합니다. 🎜🎜.prop
- DOM 속성에 강제 바인딩합니다. 3.2+🎜🎜.attr
- DOM 속성에 강제 바인딩합니다. 3.2+🎜🎜🎜🎜사용법: 🎜🎜- 🎜
class
또는 style
속성을 바인딩하는 데 사용되는 경우 v-bind
는 추가 값을 지원합니다. 배열이나 객체와 같은 유형입니다. 자세한 내용은 아래 가이드 링크를 참조하세요. 🎜🎜바인딩을 처리할 때 Vue는 기본적으로 in
연산자를 사용하여 바인딩된 키와 동일한 이름을 가진 DOM 속성이 요소에 정의되어 있는지 확인합니다. 동일한 이름의 속성이 존재하는 경우 Vue는 이를 속성으로 설정하는 대신 DOM 속성으로 할당합니다. 이 동작은 대부분의 경우 예상되는 바인딩 값 유형과 일치하지만 .prop
및 .attr
수정자를 사용하여 명시적으로 바인딩을 강제할 수도 있습니다. 때로는 이것이 필요한데, 특히 🎜Custom Elements🎜를 다룰 때 그렇습니다. 🎜🎜컴포넌트 소품 바인딩에 사용되는 경우 바인딩된 소품은 하위 구성 요소에서 올바르게 선언되어야 합니다. 🎜🎜매개변수 없이 사용하면 여러 속성 이름 바인딩 값 쌍을 포함하는 개체를 바인딩하는 데 사용할 수 있습니다. 🎜🎜<h2 v-if="isShow">Coder</h2> <h2 v-else>Bin</h2>
<h2 v-if="isShow">哈哈哈哈</h2>
4. v-else
说明: 表示 v-if
或 v-if
/ v-else-if
链式调用的“else 块”。
<h2 v-if="isShow">Coder</h2> <h2 v-else>Bin</h2>
ishow 为 true 显示 Coder,反之显示 Bin
5. v-else-if
说明: 表示 v-if
的“else if 块”。可以进行链式调用。
<template id="my-app"> <input type="text" v-model="score"> <h2 v-if="score > 90">优秀</h2> <h2 v-else-if="score > 60">良好</h2> <h2 v-else>不及格</h2> </template>
v-model 后面会说明
6. v-show
说明:基于表达式值的真假性,来改变元素的可见性。
详细描述:v-show
通过设置内联样式的 display
CSS 属性来工作,当元素可见时将使用初始 display
值。当条件改变时,也会触发过渡效果。
<template id="my-app"> <h2 v-show="isShow">哈哈哈哈</h2> </template> <script> const App = { template: '#my-app', data() { return { isShow: true } } } Vue.createApp(App).mount('#app'); </script>
v-show
不支持在 <template>
元素上使用,也不能和 v-else
搭配使用。
7. v-model
说明: 在表单输入元素或组件上创建双向绑定。
仅限: <input>
、<select>
、 <textarea>
、components
修饰符:
基本使用:
<template id="my-app"> <!-- 1.v-bind value的绑定 2.监听input事件, 更新message的值 --> <!-- <input type="text" :value="message" @input="inputChange"> --> <input type="text" v-model="message"> <h2>{{message}}</h2> </template> <script> const App = { template: '#my-app', data() { return { message: "Hello World" } }, methods: { inputChange(event) { this.message = event.target.value; } } } Vue.createApp(App).mount('#app');
绑定其他表单:
<template id="my-app"> <!-- 1.绑定textarea --> <label for="intro"> 自我介绍 <textarea name="intro" id="intro" cols="30" rows="10" v-model="intro"></textarea> </label> <h2>intro: {{intro}}</h2> <!-- 2.checkbox --> <!-- 2.1.单选框 --> <label for="agree"> <input id="agree" type="checkbox" v-model="isAgree"> 同意协议 </label> <h2>isAgree: {{isAgree}}</h2> <!-- 2.2.多选框 --> <span>你的爱好: </span> <label for="basketball"> <input id="basketball" type="checkbox" v-model="hobbies" value="basketball"> 篮球 </label> <label for="football"> <input id="football" type="checkbox" v-model="hobbies" value="football"> 足球 </label> <label for="tennis"> <input id="tennis" type="checkbox" v-model="hobbies" value="tennis"> 网球 </label> <h2>hobbies: {{hobbies}}</h2> <!-- 3.radio --> <span>你的爱好: </span> <label for="male"> <input id="male" type="radio" v-model="gender" value="male">男 </label> <label for="female"> <input id="female" type="radio" v-model="gender" value="female">女 </label> <h2>gender: {{gender}}</h2> <!-- 4.select --> <span>喜欢的水果: </span> <select v-model="fruit" multiple size="2"> <option value="apple">苹果</option> <option value="orange">橘子</option> <option value="banana">香蕉</option> </select> <h2>fruit: {{fruit}}</h2> </template> <script> const App = { template: '#my-app', data() { return { intro: "Hello World", isAgree: false, hobbies: ["basketball"], gender: "", fruit: "orange" } }, methods: { commitForm() { axios } } } Vue.createApp(App).mount('#app'); </script>
v-model修饰符的使用
<template id="my-app"> <!-- 1.lazy修饰符 --> <!-- <input type="text" v-model.lazy="message"> --> <!-- 2.number修饰符 --> <!-- <input type="text" v-model.number="message"> <h2>{{message}}</h2> <button @click="showType">查看类型</button> --> <!-- 3.trim修饰符 --> <input type="text" v-model.trim="message"> <button @click="showResult">查看结果</button> </template> <script> const App = { template: '#my-app', data() { return { message: "Hello World" } }, methods: { showType() { console.log(this.message, typeof this.message); }, showResult() { console.log(this.message); } } } Vue.createApp(App).mount('#app'); </script>
8. v-for
说明: 基于原始数据多次渲染元素或模板块。
详细描述:
指令值必须使用特殊语法 alias in expression
为正在迭代的元素提供一个别名:
<div v-for="item in items"> {{ item.text }} </div>
或者,你也可以为索引指定别名 (如果用在对象,则是键值):
<div v-for="(item, index) in items"></div> <div v-for="(value, key) in object"></div> <div v-for="(value, name, index) in object"></div>
v-for
的默认方式是尝试就地更新元素而不移动它们。要强制其重新排序元素,你需要用特殊 attribute key
来提供一个排序提示:
<div v-for="item in items" :key="item.id"> {{ item.text }} </div>
9. v-slot
说明: 用于声明具名插槽或是期望接收 props 的作用域插槽。
缩写: #
参数:插槽名 (可选,默认是 default
)
仅限:
示例
<!-- 具名插槽 --> <BaseLayout> <template v-slot:header> Header content </template> <template v-slot:default> Default slot content </template> <template v-slot:footer> Footer content </template> </BaseLayout> <!-- 接收 prop 的具名插槽 --> <InfiniteScroll> <template v-slot:item="slotProps"> <div class="item"> {{ slotProps.item.text }} </div> </template> </InfiniteScroll> <!-- 接收 prop 的默认插槽,并解构 --> <Mouse v-slot="{ x, y }"> Mouse position: {{ x }}, {{ y }} </Mouse>
10. v-text
说明: 更新元素的文本内容。
详细描述: v-text
通过设置元素的 textContent 属性来工作,因此它将覆盖元素中所有现有的内容。如果你需要更新 textContent
的部分,应该使用 mustache interpolations 代替。
<span v-text="msg"></span> <!-- 等同于 --> <span>{{msg}}</span>
11. v-html
说明: 更新元素的 innerHTML。
详细描述: v-html
的内容直接作为普通 HTML 插入—— Vue 模板语法是不会被解析的。如果你发现自己正打算用 v-html
来编写模板,不如重新想想怎么使用组件来代替。
安全说明: 在你的站点上动态渲染任意的 HTML 是非常危险的,因为它很容易导致 XSS 攻击。请只对可信内容使用 HTML 插值,绝不要将用户提供的内容作为插值
<div v-html="html"></div>
12. v-pre
说明: 跳过该元素及其所有子元素的编译。
详细描述:元素内具有 v-pre
,所有 Vue 模板语法都会被保留并按原样渲染。最常见的用例就是显示原始双大括号标签及内容。
<span v-pre>{{ this will not be compiled }}</span>
13. v-once
说明: 跳过该元素及其所有子元素的编译。
详细描述: 在随后的重新渲染,元素/组件及其所有子项将被当作静态内容并跳过渲染。这可以用来优化更新时的性能。
<!-- 单个元素 --> <span v-once>This will never change: {{msg}}</span> <!-- 带有子元素的元素 --> <div v-once> <h1>comment</h1> <p>{{msg}}</p> </div> <!-- 组件 --> <MyComponent v-once :comment="msg" /> <!-- `v-for` 指令 --> <ul> <li v-for="i in list" v-once>{{i}}</li> </ul>
14. v-cloak
说明: 用于隐藏尚未完成编译的 DOM 模板。
详细描述:该指令只在没有构建步骤的环境下需要使用。
[v-cloak] { display: none; }
<div v-cloak> {{ message }} </div>
更多编程相关知识,请访问:编程入门!!
위 내용은 Vue에서 일반적으로 사용되는 내장 명령어에 대해 이야기하는 기사 [백과사전]의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











vue.js는 중소형 프로젝트 및 빠른 반복에 적합한 반면 React는 크고 복잡한 응용 프로그램에 적합합니다. 1) vue.js는 사용하기 쉽고 팀이 불충분하거나 프로젝트 규모가 작는 상황에 적합합니다. 2) React는 더 풍부한 생태계를 가지고 있으며 고성능 및 복잡한 기능적 요구가있는 프로젝트에 적합합니다.

HTML 템플릿의 버튼을 메소드에 바인딩하여 VUE 버튼에 함수를 추가 할 수 있습니다. 메소드를 정의하고 VUE 인스턴스에서 기능 로직을 작성하십시오.

vue.js에서 JS 파일을 참조하는 세 가지 방법이 있습니다. & lt; script & gt; 꼬리표;; mounted () 라이프 사이클 후크를 사용한 동적 가져 오기; Vuex State Management Library를 통해 수입.

vue.js에서 bootstrap 사용은 5 단계로 나뉩니다 : Bootstrap 설치. main.js.의 부트 스트랩 가져 오기 부트 스트랩 구성 요소를 템플릿에서 직접 사용하십시오. 선택 사항 : 사용자 정의 스타일. 선택 사항 : 플러그인을 사용하십시오.

vue.js의 시계 옵션을 사용하면 개발자가 특정 데이터의 변경 사항을들을 수 있습니다. 데이터가 변경되면 콜백 기능을 트리거하여 업데이트보기 또는 기타 작업을 수행합니다. 구성 옵션에는 즉시 콜백을 실행할지 여부와 DEEP를 지정하는 즉시 포함되며, 이는 객체 또는 어레이에 대한 변경 사항을 재귀 적으로 듣는 지 여부를 지정합니다.

vue.js는 이전 페이지로 돌아갈 수있는 네 가지 방법이 있습니다. $ router.go (-1) $ router.back () 사용 & lt; router-link to = & quot;/quot; Component Window.history.back () 및 메소드 선택은 장면에 따라 다릅니다.

CSS 애니메이션 또는 타사 라이브러리를 사용하여 VUE에서 Marquee/Text Scrolling Effects를 구현하십시오. 이 기사는 CSS 애니메이션 사용 방법을 소개합니다. & lt; div & gt; CSS 애니메이션을 정의하고 오버플로를 설정하십시오 : 숨겨진, 너비 및 애니메이션. 키 프레임을 정의하고 변환을 설정하십시오 : Translatex () 애니메이션의 시작과 끝에서. 지속 시간, 스크롤 속도 및 방향과 같은 애니메이션 속성을 조정하십시오.

Vue DevTools를 사용하여 브라우저 콘솔에서 vue 탭을 보면 VUE 버전을 쿼리 할 수 있습니다. npm을 사용하여 "npm list -g vue"명령을 실행하십시오. package.json 파일의 "종속성"객체에서 vue 항목을 찾으십시오. Vue Cli 프로젝트의 경우 "vue -version"명령을 실행하십시오. & lt; script & gt에서 버전 정보를 확인하십시오. vue 파일을 나타내는 html 파일의 태그.
