vue.js 데이터 바인딩 작업을 수행하는 방법
이번에는 vue.js데이터 바인딩 작업을 수행하는 방법과 vue.js 데이터 바인딩 작업을 수행할 때 어떤 주의사항이 있는지 보여드리겠습니다. 다음은 실제 사례입니다.
데이터 바인딩
반응형 데이터 바인딩 시스템. 바인딩이 설정된 후 DOM은 데이터와 동기화되므로 DOM을 수동으로 유지 관리할 필요가 없습니다. 코드를 더욱 간결하고 이해하기 쉽게 만들고 효율성을 향상시킵니다.
데이터 바인딩 구문
1. 텍스트 보간
{{ }}Mustache tag
<span>Hello {{ name }}</span>
Single interpolation
DOM 변경 원인
data:{ name: 'vue' } == > Hello vue
2. HTML 속성
Mustache 태그 {{ }}
<span v-once="name">{{ name }}</span>
약어:
<p v-bind:id="'id-'+id"></p>
3.Mustache 태그 안에 배치된 텍스트 콘텐츠입니다. 속성 값을 직접 출력하는 것 외에도 결합 표현식은 간단한 JavaScript 표현식과 선택적으로 하나 이상의 필터로 구성될 수 있습니다(정규 표현식
은 지원되지 않습니다. 복잡한 변환이 필요한 경우 처리를 위해 필터 프로세서 또는 계산된 속성을 사용하세요).<p :id="'id-'+id"></p>
vue.js를 사용하면 파이프 문자 "|"로 표시된 표현식 뒤에 선택적 필터를 추가할 수 있습니다.
{{ index + 1}} {{ index == 0 ? 'a' : 'b' }} {{name.split('').join('|') }} {{ var a = 1 }} //无效
함수
의 반환 값이 출력 결과입니다. arg1 및 arg2는 표현식을 사용하거나 작은따옴표를 추가하여 문자열을 직접 전달할 수 있습니다.{{ name | uppercase }} // Vue.js将name的值传入给uppercase这个内置的过滤器中(本质是一个函数),返回字符串的大写值。 {{ name | filterA | filterB }} //多个过滤器链式使用 {{ name | filterA arg1 arg2 }} //传入多个参数
capitalize
: 문자열의 첫 문자가 대문자로 변환됩니다.uppercase: 문자열을 대문자로 변환합니다.
lowercase: 문자열을 소문자로 변환합니다.
currency: 매개변수는 {String}[통화 기호], {숫자}[소수 자릿수]이며, 숫자를 통화 기호로 변환하고 숫자 섹션 번호를 자동으로 추가합니다.
{{ name.split('') | limitBy 3 1 }} // ->u,e
{{ amount | currency '¥' 2 }} //若amount值为1000,则输出为¥1,000.00
<p v-for="c in count">{{ c | pluralize 'item' }} {{ c | pliralize 'st' 'nd' 'rd' 'th' }} </p>
debounce
: 들어오는 값은 함수여야 하며 매개 변수는 선택 사항이며 지연 길이인 {Number}[wait]입니다. 그 결과 함수가 호출된 후 n밀리초가 될 때까지 작업이 실행되지 않습니다.//输出结果: 1item 1st 2items 2nd 3items 3rd 4items 4th
{Number}limit
, {Number}[offset]
이고,limit는 표시할 숫자입니다. , 오프셋은 배열 첨자 표시를 시작합니다.
<input v-on:keyup="onKeyup | debounce 500"> //input元素上监听了keyup事件,并且延迟500ms触发
{Number}limit
,{Number}[offset]
,limit为显示个数,offset为开始显示数组下标。<p v-for="item in items | limitBy 10"></p> //items为数组,且只显示数组中的前十个元素
filterBy:传入值必须是数组,参数为{String | Function}targetStringOrFunction
,即需要匹配的字符串或函数;"in"可选分隔符。{String}[...searchKeys]
,为检索的属性区域。
<p v-for="name in names | filterBy '1.0'">{{ name }}</p> //检索names数组中值包含1.0的元素 <p v-for="item in items | filterBy '1.0' in 'name'">{{ item | json }}</p> //检索items中元素属性name值为1.0的元素输出。检索区域也可以为数组,即in [name,version],在多个属性中进行检索。
//输出结果 vue1.0 {"name":"vue1.0","version":"1.0"}
使用自定义的过滤函数,函数可以在选项methods中定义
<p v-for="item in items | filterBy customFilter" methods:{ cuestomFilter:function(item){ if(item.name) return true; //检索所有元素中包含name属性的元素 } }
orderBy:传入值必须是数组,参数为{String|Array|Function}sortKeys
: 들어오는 값은 배열이어야 하며 매개변수는 {String | Function}targetStringOrFunction
입니다. 이는 "in"이 일치해야 하는 문자열 또는 함수입니다. 선택적 구분 기호. {String}[...searchKeys]
는 검색된 속성 영역입니다.
<p v-for="item in items | orderBy 'name' -1">{{ item.name}}</p> //items数组中以键名name进行降序排列
<p v-for="item in items | orderBy [name,version]">{{item.name}}</p> //使用items里的两个键名进行排序
맞춤 필터 함수를 사용하세요. 함수는 옵션 메서드에서 정의할 수 있습니다
<p v-for="item in items | orderBy customOrder">{{item.name}}</p> methods:{ customOrder: function(a,b){ return parseFloat(a.version) > parseFloat(b.version) //对比item中version的值的大小进行排序 } }
: 들어오는 값은 배열이어야 하며 매개변수는 {String|Array|Function}sortKeys입니다. code>, 즉 정렬 전략을 지정합니다.
단일 키 이름: <img v-bind:src="avatar" /> <==> <img src="{{avatar}}" />
<button v-on:click.stop="doClick"></button> //stop:停止冒泡。相当于调用了e.stopPropagagation().
사용자 정의 정렬 기능:
var vm = new Vue({ el: '#app', data: { firstName:'Gavin', lastName:'CLY' }, computed: { fullName:function(){ //this指向vm实例 return this.firstName + ' ' + this.lastName; } } })
<img v-bind:src="avatar" /> <==> <img src="{{avatar}}" />
修饰符:以半角句号.开始的特殊后缀,用于表示指令应该以特殊方式绑定。
<button v-on:click.stop="doClick"></button> //stop:停止冒泡。相当于调用了e.stopPropagagation().
计算属性
避免在模板中加入过重的业务逻辑,保证模版的结构清晰和可维护性。
1.基础例子
var vm = new Vue({ el: '#app', data: { firstName:'Gavin', lastName:'CLY' }, computed: { fullName:function(){ //this指向vm实例 return this.firstName + ' ' + this.lastName; } } })
<p>{{ firstName }}</p> //Gavin <p>{{ lastName }}</p> //CLY <p>{{ fullName }}</p> //Gavin CLY
注:此时对vm.firstName
和vm.lastName
进行修改,始终会影响vm.fullName
。
2.Setter
更新属性时带来便利
var vm = new Vue({ el:'#el', data:{ cents:100 }, computed:{ price:{ set:function(newValue) { this.cents = newValue * 100; }, get:function(){ return (this.cents / 100).toFixed(2); } } } })
表单控件
v-model:对表单元素进行双向数据绑定,在修改表单元素值时,实例vm中对应的属性值也同时更新,反之亦然。
var vm = new Vue({ el:'#app', data: { message: '', gender: '', cheched: '', multiChecked: '', a: 'checked', b: 'checked' } })
1. Text
输入框示例,用户输入的内容和vm.message直接绑定:
<input type="text" v-model="message" /> <span>Your input is : {{ message }} </span>
2. Radio
单选框示例:
<label><input type="radio" value="male" v-model="gender">男</lable> <label><input type="radio" value="famale" v-model="gender">女</lable> <p>{{ gender }}</p> //显示的是value值
3.Checkbox
单个勾选框,v-model即为布尔值,此时Input的value并不影响v-model的值。
<input type="checkbox" v-model="checked" /> <span>checked: {{ checked }} </span> //显示的是true/false
多个勾选框,v-model使用相同的属性名称,且属性为数组。
<label><input type="checkbox" value="1" v-model="multiChecked">1</label> <label><input type="checkbox" value="1" v-model="multiChecked">2</label> <label><input type="checkbox" value="1" v-model="multiChecked">3</label> <p>MultiChecked:{{ multiChecked.join{'|'} }}</p> //multiChecked:1|2
4.Select
单选
<select v-model="selected"> <option selected>A</option> <option>B</option> <option>C</option> </select> <span>Selected: {{ selected }}</span>
多选
<select v-model="multiSelected" multiple> <option selected>A</option> <option>B</option> <option>C</option> </select> <span>MultiSelected: {{ multiSelected.join('|') }}</span>
5.绑定value
通过v-bind实现,表单控件的值绑定到Vue市里的动态属性上。
Checkbox
<input type="checkbox" v-model="checked" v-bind:true-value="a" v-bind:false-value="b" />
选中:
vm.checked == vm.a //=> true
未选中:
vm.checked == vm.b //=>true
Radio
<input type="radio" v-model="checked" v-bind:value="a" >
选中:
vm.checked == vm.a //=> true
3.Select Options
<select v-model="selected"> <!-- 对象字面量 --> <option v-bind:value="{ number:123}">123</option> </select>
选中:
typeof vm.selected //=> object vm.selected.number //=> 123
6.参数特性
.lazy:默认情况下,v-model在input事件中同步输入框与数据,加lazy属性后会在change事件中同步。
<!-- 在 "change" 而不是 "input" 事件中更新 --> <input v-model.lazy="msg" >
.number:自动将用户输入转为Number类型,如果原值转换结果为NaN,则返回原值。
<input v-model.number="age" type="number">
.trim:如果要自动过滤用户输入的首尾空格,可以添加 trim 修饰符到 v-model 上过滤输入
<input v-model.trim="msg">
Class与Style绑定
1.Class绑定
对象语法:v-bind:class
接受参数是一个对象,而且可以与普通的class属性共存。
<p class="tab" v-bind:class="{'active':active,'unactive':!active}"></p>
vm实例中需要包含:
data:{ active:true }
渲染结果为:
<p class="tab active"></p>
数组语法:v-bind:class
也接受数组作为参数。
<p v-bind:class="[classA,classB]"></p>
vm实例中需要包括:
data:{ classA:"class-a", classB:"class-b" }
渲染结果为:
<p class="class-a class-b"></p>
使用三元表达式切换数组中的class
<p v-bind:class="[classA,isB?classB:""]"></p>
若
vm.isB = false
则渲染结果为
<p class="class-a"></p>
2.内联样式绑定(style属性绑定)
对象语法:直接绑定符合样式格式的对象。
<p v-bind:style="alertStyle"></p>
vm实例中包含:
data:{ alertStyle:{ color: 'red', fontSize: '2px' } }
<p v-bind:style="{fontSize:alertStyle.fontSize,color:'red'}"></p>
数组语法:v-bind:style
允许将多个样式对象绑定到同一元素上。
<p v-bind:style="[ styleObjectA,styleObjectB]" .></p>
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
위 내용은 vue.js 데이터 바인딩 작업을 수행하는 방법의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











WebSocket 및 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법 소개: 지속적인 기술 개발로 음성 인식 기술은 인공 지능 분야의 중요한 부분이 되었습니다. WebSocket과 JavaScript를 기반으로 한 온라인 음성 인식 시스템은 낮은 대기 시간, 실시간, 크로스 플랫폼이라는 특징을 갖고 있으며 널리 사용되는 솔루션이 되었습니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법을 소개합니다.

WebSocket과 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 서론: 인터넷 기술의 급속한 발전과 함께 실시간 모니터링 시스템이 다양한 분야에서 널리 활용되고 있다. 실시간 모니터링을 구현하는 핵심 기술 중 하나는 WebSocket과 JavaScript의 조합입니다. 이 기사에서는 실시간 모니터링 시스템에서 WebSocket 및 JavaScript의 적용을 소개하고 코드 예제를 제공하며 구현 원칙을 자세히 설명합니다. 1. 웹소켓 기술

JavaScript 및 WebSocket을 사용하여 실시간 온라인 주문 시스템을 구현하는 방법 소개: 인터넷의 대중화와 기술의 발전으로 점점 더 많은 레스토랑에서 온라인 주문 서비스를 제공하기 시작했습니다. 실시간 온라인 주문 시스템을 구현하기 위해 JavaScript 및 WebSocket 기술을 사용할 수 있습니다. WebSocket은 TCP 프로토콜을 기반으로 하는 전이중 통신 프로토콜로 클라이언트와 서버 간의 실시간 양방향 통신을 실현할 수 있습니다. 실시간 온라인 주문 시스템에서는 사용자가 요리를 선택하고 주문을 하면

WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법 오늘날의 디지털 시대에는 점점 더 많은 기업과 서비스에서 온라인 예약 기능을 제공해야 합니다. 효율적인 실시간 온라인 예약 시스템을 구현하는 것이 중요합니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. WebSocket이란 무엇입니까? WebSocket은 단일 TCP 연결의 전이중 방식입니다.

JavaScript 및 WebSocket: 효율적인 실시간 일기 예보 시스템 구축 소개: 오늘날 일기 예보의 정확성은 일상 생활과 의사 결정에 매우 중요합니다. 기술이 발전함에 따라 우리는 날씨 데이터를 실시간으로 획득함으로써 보다 정확하고 신뢰할 수 있는 일기예보를 제공할 수 있습니다. 이 기사에서는 JavaScript 및 WebSocket 기술을 사용하여 효율적인 실시간 일기 예보 시스템을 구축하는 방법을 알아봅니다. 이 문서에서는 특정 코드 예제를 통해 구현 프로세스를 보여줍니다. 우리

사용법: JavaScript에서 insertBefore() 메서드는 DOM 트리에 새 노드를 삽입하는 데 사용됩니다. 이 방법에는 삽입할 새 노드와 참조 노드(즉, 새 노드가 삽입될 노드)라는 두 가지 매개 변수가 필요합니다.

JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법, 특정 코드 예제가 필요합니다. 서문: 웹 개발에서는 서버와의 데이터 상호 작용이 종종 포함됩니다. 서버와 통신할 때 반환된 HTTP 상태 코드를 가져와서 작업의 성공 여부를 확인하고 다양한 상태 코드에 따라 해당 처리를 수행해야 하는 경우가 많습니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법과 몇 가지 실용적인 코드 예제를 제공합니다. XMLHttpRequest 사용

JavaScript는 웹 개발에 널리 사용되는 프로그래밍 언어인 반면 WebSocket은 실시간 통신에 사용되는 네트워크 프로토콜입니다. 두 가지의 강력한 기능을 결합하면 효율적인 실시간 영상 처리 시스템을 만들 수 있습니다. 이 기사에서는 JavaScript와 WebSocket을 사용하여 이 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 첫째, 실시간 영상처리 시스템의 요구사항과 목표를 명확히 할 필요가 있다. 실시간 이미지 데이터를 수집할 수 있는 카메라 장치가 있다고 가정해 보겠습니다.
