亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解Vue的數(shù)據(jù)及事件綁定和filter過濾器

 更新時(shí)間:2022年01月12日 15:41:53   作者:星河夢~  
這篇文章主要為大家介紹了Vue的數(shù)據(jù)及事件綁定和filter過濾器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助

Vue數(shù)據(jù)綁定

單向綁定

將Model綁定到View后,當(dāng)用JavaScript代碼更新Model時(shí),View會(huì)自動(dòng)更新。(模型——>視圖

單向綁定的實(shí)現(xiàn)過程是:

  • 所有數(shù)據(jù)只保存一份。
  • 一旦數(shù)據(jù)變化,就去更新頁面(只有data——>DOM,沒有DOM——>data)
  • 若用戶在頁面上做了更新,就手動(dòng)收集(雙向綁定式自動(dòng)收集),合并到原有的數(shù)據(jù)中。

單向綁定的應(yīng)用:

(1)插值綁定:是數(shù)據(jù)綁定的基本形式,用{{}}實(shí)現(xiàn)。

(2)v-bind綁定:如果HTML的某些屬性可以支持單向綁定,那么只要在該屬性前面加上v-bind指令,這樣Vue在解析時(shí)會(huì)識(shí)別出該指令,將屬性值和Vue實(shí)例的Model進(jìn)行綁定。

然后就可以通過Model來動(dòng)態(tài)操作該屬性,從而實(shí)現(xiàn)DOM的聯(lián)動(dòng)更新。

例如:

<div id="app">
    <img v-bind:src='src' :title="title">
</div>
<script>
    new Vue({
        el:'#app',
        data:{
            src:'../images/8.png.jpeg',   //修改Model后,視圖也跟著改變
            title:'蝴蝶'
        }
    })
</script>

雙向綁定

Vue框架的核心功能就是數(shù)據(jù)雙向綁定。

雙向綁定:把Model綁定到View的同時(shí)也將View綁定到Model上,這樣既可以通過更新Model來實(shí)現(xiàn)View的自動(dòng)更新,也可以通過更新View來實(shí)現(xiàn)Model數(shù)據(jù)的更新。

能夠?qū)崿F(xiàn)數(shù)據(jù)雙向綁定的元素——表單元素(input、textarea、select等),使用v-model指令綁定。

內(nèi)容復(fù)制方式:相當(dāng)于淺拷貝

例如:

<div id="app">
   <h2>{{message}}</h2>
   <input type="text" v-model="message">
</div>
<script>
   var vm=new Vue({
       el:'#app',
       data:{
           message:'數(shù)據(jù)雙向綁定'
       }
   })
</script>
  • 模型影響視圖:data數(shù)據(jù)message變了,div里面的內(nèi)容變了;
  • 視圖影響模型:input輸入框的內(nèi)容改變,data里面的message也改變,從而h2里面的內(nèi)容也改變 。

值綁定

v-model用來在View與Model之間同步數(shù)據(jù)。

但是有時(shí)候需要控制同步發(fā)生的時(shí)機(jī),或者在數(shù)據(jù)同步到Model前將數(shù)據(jù)轉(zhuǎn)換為Number類型——在v-model指令所在的form控件上添加相應(yīng)的修飾指令。

修飾符:

.lazy(懶加載)修飾符

<div id="app">
    <input type="text" v-model.lazy='msg'>
    <p>{{msg}}</p>
</div>
<script>
    new Vue({
        el:'#app',
        data:{
            msg:'懶加載'
        }
    })
</script>

在這里插入圖片描述

  • .number修飾符
  • .trim修飾符

例如:

<div id="app">
    <input type="text" v-model.number='num'>
    <p>num的類型:{{typeof(num)}}</p>
    <!--<input type="text" v-model.trim="val">  -->
    <!--<p>val的長度是:{{ val.length }}</p>  -->
</div>
<script>
    new Vue({
        el:'#app',
        data:{
            num:''
        }
    })
</script>

事件綁定

通過v-on指令來綁定事件。

事件處理器

(1)方法處理器:可以用v-on指令監(jiān)聽DOM事件。(直接綁定到一個(gè)方法

(2)內(nèi)聯(lián)語句處理器:除了直接綁定到一個(gè)方法,也可以用內(nèi)聯(lián) JavaScript 語句

<div id="example">
    <button v-on:click="say('hi')">Say Hi</button>       //內(nèi)聯(lián)語句處理器
    <button v-on:click="say('what')">Say What</button>
	<!-- <a  v-on:click="say('hello',$event)">
去百度</a>  -->       //內(nèi)聯(lián)語句處理器中訪問原生 DOM 事件
</div>
<script>
    new Vue({
        el: '#example',
        methods: {
            say: function (msg) {
                alert(msg)
            }
            //say: function (msg,event) {
                   // event.preventDefault()
               // }
        }
    })
</script>

注意:沒有括號(hào)的是函數(shù)名;有括號(hào)的實(shí)際是一條JS語句,稱為內(nèi)聯(lián)處理器。

事件修飾符 

  • .stop - 阻止冒泡
  • .prevent - 阻止默認(rèn)事件
  • .capture - 使用capture模式添加事件監(jiān)聽器
  • .self - 只監(jiān)聽觸發(fā)該元素的事件
  • .once - 只觸發(fā)一次

例如:

<a v-on:click.stop="doThis"></a>
<div v-on:click.capture="doThis">...</div>

鍵值修飾符 

  • .enter - enter事件
  • .left - 左鍵事件
  • .right - 右鍵事件
  • .middle - 中間滾輪事件

例如:

<input v-on:keyup.enter="submit"><!-- 縮寫語法 --><input @keyup.enter="submit"><input v-on:keyup.enter="submit">
<!-- 縮寫語法 -->
<input @keyup.enter="submit">

class與style綁定

綁定class

可以給v-bind:class傳一個(gè)對象或數(shù)組,通過v-on綁定事件改變樣式。

<div id="example" v-bind:class="colorName" v-on:click="changeColor">

<div id="example" v-bind:class="[class1,class2]" v-on:click="changeColor"></div>

綁定內(nèi)聯(lián)樣式

v-bind:style傳一個(gè)對象或數(shù)組。

<div v-bind:style="{color:fontColor,fontSize:mySize}">西柚
 data: {
    fontColor: 'white',
    mySize: '30px'
 }
 
<div v-bind:style="[baseStyles,vueStyles]">西安郵電大學(xué)</div>
 data: {
     baseStyles:{ 'color': 'red'},
     vueStyles: { 'font-size':'35px'}
 }

filter過濾器

1、在Vue.js中,過濾器主要用于

  • 文本格式化
  • 日期格式化
  • 數(shù)組數(shù)據(jù)的過濾

2、使用的位置

(1)插值表達(dá)式:({表達(dá)式|過濾器})

{{ message | filterA }}

(2)v-bind:屬性|過濾器

<div v-bind:id="rawId | formatId"></div>

3、使用方法:管道符(|)

4、本質(zhì):本質(zhì)是一個(gè)函數(shù)

5、分類:

(1)全局過濾器

Vue.filter(‘過濾器名',function(){
實(shí)現(xiàn)過濾功能
})
Vue.filter('filterA',function (value) {
    return value+'Hello'
})
new Vue({})

(2)局部過濾器:在Vue實(shí)例中通過filter選項(xiàng)來定義

new Vue({
	el:'#id',
	//filters{
		//過濾器名:function(參數(shù)){
		//過濾功能
		//}
	//}
	filters:{     //局部過濾器,只能在當(dāng)前vue實(shí)例綁定的div里面用
		filterA:function(value){
			return value+'Hello'
		}
	}
})

(3)過濾器的串聯(lián)

{{ message | filterA | filterB }}

message作為參數(shù)——>過濾器函數(shù)filterA——>過濾器filterB

或者:

{{ message | filterA('arg1', arg2) }}

filterA 被定義為接收三個(gè)參數(shù)的過濾器函數(shù)。其中 message 的值作為第一個(gè)參數(shù), ‘arg1’ 作為第二個(gè)參數(shù),arg2 的值作為第三個(gè)參數(shù)。

例如:

<div id="app">
    <p>{{'2022'|filterA|filterB}}</p>
</div>
<script>
    new Vue({
        el:'#app',
        filters:{
            filterA:function(value){
                return value+' is'
            },
            filterB:function(value){
                return value+' coming!'
            }
        }
    })
</script>

在這里插入圖片描述

總結(jié)

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • vue項(xiàng)目如何全局修改el-button樣式

    vue項(xiàng)目如何全局修改el-button樣式

    這篇文章主要介紹了vue項(xiàng)目如何全局修改el-button樣式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Vue3使用ref與reactive創(chuàng)建響應(yīng)式對象的示例代碼

    Vue3使用ref與reactive創(chuàng)建響應(yīng)式對象的示例代碼

    這篇文章主要詳細(xì)介紹了Vue3使用ref與reactive創(chuàng)建響應(yīng)式對象的方法步驟,文中通過代碼示例和圖文結(jié)合的方式給大家介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下
    2024-02-02
  • 淺談VUE uni-app 自定義組件

    淺談VUE uni-app 自定義組件

    這篇文章主要介紹了uni-app 的自定義組件,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-10-10
  • vue+moment實(shí)現(xiàn)倒計(jì)時(shí)效果

    vue+moment實(shí)現(xiàn)倒計(jì)時(shí)效果

    這篇文章主要為大家詳細(xì)介紹了vue+moment實(shí)現(xiàn)倒計(jì)時(shí)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • vue-cli3 從搭建到優(yōu)化的詳細(xì)步驟

    vue-cli3 從搭建到優(yōu)化的詳細(xì)步驟

    這篇文章主要介紹了vue-cli3 從搭建到優(yōu)化的詳細(xì)步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-01-01
  • vue打包后生成一個(gè)配置文件可以修改IP

    vue打包后生成一個(gè)配置文件可以修改IP

    本文主要介紹了修改Vue項(xiàng)目運(yùn)行的IP和端口,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • vue使用動(dòng)畫實(shí)現(xiàn)滾動(dòng)表格效果

    vue使用動(dòng)畫實(shí)現(xiàn)滾動(dòng)表格效果

    這篇文章主要為大家詳細(xì)介紹了vue使用動(dòng)畫實(shí)現(xiàn)滾動(dòng)表格效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Vue3?PC端頁面開發(fā)規(guī)范及說明

    Vue3?PC端頁面開發(fā)規(guī)范及說明

    這篇文章主要介紹了Vue3?PC端頁面開發(fā)規(guī)范及說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 使用Element時(shí)默認(rèn)勾選表格toggleRowSelection方式

    使用Element時(shí)默認(rèn)勾選表格toggleRowSelection方式

    這篇文章主要介紹了使用Element時(shí)默認(rèn)勾選表格toggleRowSelection方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 解決vue的component標(biāo)簽渲染問題

    解決vue的component標(biāo)簽渲染問題

    這篇文章主要介紹了解決vue的component標(biāo)簽渲染問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03

最新評(píng)論