欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue的表單數(shù)據(jù)收集案例之基本指令和自定義指令詳解

 更新時間:2023年01月05日 09:44:09   作者:huisheng_qaq  
收集表單數(shù)據(jù)可以使用這個v-model實現(xiàn)這個數(shù)據(jù)的綁定,但是在有些輸入框中,還需要一些其他的指令搭配這個v-model指令結(jié)合使用,這篇文章主要介紹了vue的表單數(shù)據(jù)收集,基本指令和自定義指令,需要的朋友可以參考下

一,vue的核心屬性

1,收集表單數(shù)據(jù)

1.1,收集數(shù)據(jù)案例

可以使用這個v-model實現(xiàn)這個數(shù)據(jù)的綁定,但是在有些輸入框中,還需要一些其他的指令搭配這個v-model指令結(jié)合使用。

1.1.1,type類型的輸入框

這種方式的輸入框,是可以直接通過這個v-model獲取到值的。因為v-model默認就是收集輸入框的value值

賬號:<input type="type" v-model = "userInfo.account"> <br/><br/>
密碼:<input type="type" v-model = "userInfo.possword"> <br/><br/>

<!-- vue實例中的data數(shù)據(jù) -->
 data:{
	userInfo:{
     	account:'',
         possword:''
     }
 }
1.1.2,radio類型的單選框

和上面的type類型不一樣,因為上面的text類型有輸入的value,而這種類型的數(shù)據(jù)沒有輸入值,只有單選值,因此需要在這個標簽內(nèi)部加上這個value值,這樣才能獲取到選擇的值。

性別:
男<input type="radio" name="sex" v-model = "userInfo.sex"  value="male">
女<input type="radio" name="sex" v-model = "userInfo.sex" value="female"> <br/><br/>
    
<!-- vue實例中的data數(shù)據(jù) -->
 data:{
	userInfo:{
     	sex:''
     }
 }
1.1.3,checkbox類型的復(fù)選框

在這個復(fù)選框中,由于也和這個單選框一樣,只有選擇,沒有具體的輸入這個value值,因此需要在標簽內(nèi)部加上這個value值,除了需要在這個標簽內(nèi)部加上這個value值之外,還需要在vue實例的data中,通過數(shù)組的方式接收這個復(fù)選框所選擇的值。

愛好:
學(xué)習<input type="checkbox" v-model = "userInfo.hobby" value="study">
運動<input type="checkbox" v-model = "userInfo.hobby" value="sport">
打游戲<input type="checkbox" v-model = "userInfo.hobby" value="games">  <br/><br/>

<!-- vue實例中的data數(shù)據(jù) -->
 data:{
	userInfo:{
     	hobby:[]
     }
 }

如果復(fù)選框沒有這個value值,那么勾選的本質(zhì)就是一個布爾屬性,如需要在勾選注意事項的時候,是可以不需要這個value值的,并且在data中接收到的這個值也是一個布爾值。

<input type="checkbox" v-model = 'userInfo.agree'>接受并訂閱

<!-- vue實例中的data數(shù)據(jù) -->
 data:{
	userInfo:{
     	agree:''
     }
 }
1.1.4,select類型的下拉框

這個由于也是選擇框,沒有輸入具體的數(shù)據(jù),因此需要在option中配置value值。并且在vue實例中的data數(shù)據(jù)用字符串接收即可。

所屬地區(qū):
<select v-model="userInfo.city">
    <option value="">請選擇所屬地區(qū)</option>
    <option value="江西">江西</option>
    <option value="廣東">廣東</option>
    <option value="貴州">貴州</option>
    <option value="貴州">湖南</option>
</select> <br/><br/>

<!-- vue實例中的data數(shù)據(jù) -->
 data:{
	userInfo:{
     	city:''
     }
 }

1.2,收集表單數(shù)據(jù)總結(jié)

text

若輸入框是一個文本屬性,則v-model收集的值是value值,用戶輸入的值就是value值

<input type = "text">

radio

若輸入框是一個單選框,則v-model收集的是value值,并且在標簽內(nèi)需要配置value值

<input type = "radio">

checkbox

若輸入框是一個復(fù)選框,那就需要分情況討論

1,如果input中沒有配置value屬性,那么收集到的就是一個是否勾選的checked,是一個布爾值

2,如果input輸入框中有配置value的屬性:

(1).如果在data中的初始值是一個非數(shù)組,如一個字符串,那么收集到的也是checked的布爾值

(2).如果data中的初始值是一個數(shù)組,那么收集到的就是value組成的數(shù)組

1.3,v-model的三個修飾符

lazy

指的是失去焦點在收集數(shù)據(jù),如下在文本框中輸入數(shù)據(jù)時,不需要實時的根據(jù)用戶的輸入或者刪除將內(nèi)容進行數(shù)據(jù)的收集,而是在點擊其他組件,失去焦點的時候再去收集全部的數(shù)據(jù)

 <textarea v-model.lazy="userInfo.other"></textarea> <br/><br/>

number

輸入字符串轉(zhuǎn)化為有效的數(shù)字,比如在輸入用戶的年齡或者電話號碼的時候,如果后端沒有做這個是否為全部數(shù)字的校驗的時候,那么就可以通過這個指令進行校驗了。這個指令一般搭配這個輸入框的number類型一起使用

年齡:<input type="number" v-model.number = "userInfo.age"> <br/><br/>

trim

對輸入的數(shù)據(jù)進行收尾的去除空格。這個在實際開發(fā)中,如果后端沒有及時的對前端傳過來的數(shù)據(jù)進行一個字符串的去空格的話,也是可以通過前端的這個指令進行一個數(shù)據(jù)的去重的。

賬號:<input type="type" v-model.trim = "userInfo.account"> <br/><br/>

2,指令

2.1,基本指令

在vue內(nèi)部提供了很多可以直接使用的指令,如一些使用比較頻繁的指令,如下

v-bind:單向綁定			v-model:雙向綁定 			v-for:遍歷數(shù)組			v-on:監(jiān)聽事件
v-if:條件渲染(控制結(jié)點是否存在)		v-show:條件渲染(控制結(jié)點是否展示)		v-else:配合v-if使用

除了上面這些使用的頻繁的基本指令之外,vue也提供了很多的其他指令

2.2.1,v-text

可以直接在標簽中使用,將會把標簽所在的結(jié)點渲染文本內(nèi)容

<div v-text = "name"></div>
<div>{{name}}</div>
<!-- vue實例中的data數(shù)據(jù) -->
data:{
	name:'zhs'
}

但是使用這個標簽的時候,v-text會替換掉整個結(jié)點的內(nèi)容,如果直接使用 {{}} 的插值語法獲取值,就不會替換,因此直接使用 {{}} 來獲取值更靈活。

但是如果整個節(jié)點只有數(shù)據(jù)中的那一個值,如上面的只有name值,那么v-text和這個插值語法是等價的,如果結(jié)點中還有其他值,那么就不推薦使用這個v-text了。如下,如果結(jié)點中還有你好兩個字,那么就不能使用v-text,而是需要使用下面的雙花括號 的插值語法的形式獲取值。

<div v-text = "name"></div>
<div>你好,{{name}}</div>

同樣這個結(jié)點也不會去解析data數(shù)據(jù)中的含有標簽的值。如下,如果實例中的值是一個含有標簽的值,在使用v-text的時候,會直接將這個str的這個值以文本的形式直接渲染在結(jié)點中,而不會對里面的標簽進行一個解析。

<div v-text = "str"></div>
<!-- vue實例中的data數(shù)據(jù) -->
data:{
	str:"<h3> 你好!</h3>"
}
2.2.2,v-html

這個v-html和這個v-text的這個文本使用是一樣的,可以替換整個結(jié)點的內(nèi)容。但是和v-text不一樣的就是,v-html可以對data數(shù)據(jù)中的內(nèi)容進行一個html的解析,如果數(shù)據(jù)中的字符串有html的標簽,那么會直接對這些標簽進行一個解析。

<div v-text = "str"></div>
<!-- vue實例中的data數(shù)據(jù) -->
data:{
	str:"<a href = "www.baidu.com"> 點我跳轉(zhuǎn)百度</h3>"
}

但是在使用這個v-html的時候,會帶有一定的安全性的問題,如果在網(wǎng)站上動態(tài)的渲染html,會容易的導(dǎo)致XSS攻擊,因此一定要在可信的內(nèi)容上使用v-html

2.2.3,v-clock

該指令是一個沒有值的指令,如果在網(wǎng)速慢時,導(dǎo)致vue實例加載比較慢,從而讓html頁面給正常加載在頁面,讓用戶看到一些未經(jīng)加載的不友好的頁面時,可以使用這個v-clock。

v-clock一般搭配這個css中的屬性樣式使用,如果在網(wǎng)速慢時,導(dǎo)致這個 {{name}} 直接以文本的形式渲染在頁面上,那么可以先使用這個display這個屬性將對應(yīng)的html的內(nèi)容暫時給隱藏掉,在加載到vue實例之后,那么這個v-clock這個指令就會被刪除,那么這個display也使用不上,那么這個name對應(yīng)的值就會被正常的展示

<style>
    //只有是這個v-clock屬性的都有下面的樣式
	[v-clock]{
    	display:none;
	}    
</style>
<div id = "root">
	<h1 v-clock>{{name}}</h1>
</div>
<!-- vue實例中的data數(shù)據(jù) -->
data:{
	name:'zhs'
}
2.2.4,v-once

該指令也是一個沒有值的指令,就是值在標簽中使用這個指令之后,初次渲染這個值是一個動態(tài)指令,渲染完這個值之后會這里面的內(nèi)容就會變成一個靜態(tài)的內(nèi)容,以后數(shù)據(jù)發(fā)生改變的時候不會引起v-once所在結(jié)果的更新。

<div id = "root">
	<h1 v-once>初始值為:{{n}}</h1>
    <h1>當前n的值為:{{n}}</h1>
    <button @click="n++">點我n+1</button>
</div>
<!-- vue實例中的data數(shù)據(jù) -->
data:{
	n:1
}
2.2.5,v-pre

這個結(jié)點也是沒有值的,如果在結(jié)點上加了這個這個指令,那么vue會跳過該結(jié)點的編譯過程,就是會將開發(fā)人員在結(jié)點上寫的內(nèi)容直接渲染在頁面上,因此這個指令最好不要亂加。但是也可以通過添加這個指令,將一些沒有使用到指令語法,插值語法的結(jié)點更快的加速編譯。

如下第一個h1標簽為純文本,和vue實例沒有太大關(guān)系,因此為了加速編譯,可以直接使用這個v-pre指令。

<div id = "root">
	<h1 v-pre>vue其實很簡單</h1>
    <h1>當前n的值為:{{n}}</h1>
    <button @click="n++">點我n+1</button>
</div>
<!-- vue實例中的data數(shù)據(jù) -->
data:{
	n:1
}

2.2,自定義指令

2.2.1,函數(shù)式自定義指令

就是自定義一些vue中不存在的指令,可以在vue實例中通過這個directives來實現(xiàn),他和data平級,里面通過定義函數(shù)來實現(xiàn)這個自定義的命令,在定義函數(shù)時不需要加上v- ,不過在使用的時候需要加上。

假設(shè)一個需求,定義一個 v-big 的指令,其功能和v-text類似,但是會將綁定的數(shù)值放大10倍。其完成的代碼實現(xiàn)如下:

<div id="root">
    <h1>當前元素的值是:<span v-text = "n"></span></h1>
    <h1>放大10倍后的值是:<span v-big = "n"></span></h1>
    <button @click="n++">點我n+1</button>
</div>

<script type="text/javascript" >
    Vue.config.productionTip = false    //阻止vue啟動時提示生產(chǎn)提示
    new Vue({
        //指定當前實例為哪個容器服務(wù),id對應(yīng)#,class對應(yīng).
        el:'#root',
        //data用于存儲數(shù)據(jù),只有el對應(yīng)的容器可以使用
        data:{
            n:1
        },
        directives:{
            // element:一個真實的dom元素span
            // binding:標簽和元素之間的綁定,即span和這個big之間的綁定           
            big(element,binding){
                //修改元素里面的值
                element.innerText = binding.value * 10;
                console.log(element,binding)
            }
        }
    })
</script>

并且big函數(shù)被調(diào)用的時機有兩種

1:指令與元素成功綁定時,就是一上來第一次使用的時候

2:指令所在的模板被重新解析時被調(diào)用,比如data中有數(shù)據(jù)發(fā)生改變

2.2.3,對象式自定義指令

再來一個需求,就是自定義一個v-fbind指令,和v-bind功能類似,但可以讓其所綁定的input元素默認的獲取焦點。

<div id="root">
    <input type="text" v-fbind:value = "n">
</div>

<script type="text/javascript" >
    Vue.config.productionTip = false    //阻止vue啟動時提示生產(chǎn)提示
    new Vue({
        //指定當前實例為哪個容器服務(wù),id對應(yīng)#,class對應(yīng).
        el:'#root',
        //data用于存儲數(shù)據(jù),只有el對應(yīng)的容器可以使用
        data:{
            n:1
        },
        directives:{
            fbind:{
                //指令與元素成功綁定時
                bind(element,binding){
                    element.value = binding.value * 10
                },
                //指令所在元素被插入頁面時
                inserted(element,binding){
                    element.focus();
                },
                //指令所在的模板被重新解析時被調(diào)用 
                update(element,binding){
                    element.value = binding.value * 10
                }
            }
        }
    })
</script>

從上面兩段可以發(fā)現(xiàn),這個函數(shù)式的寫法就是對象式的簡寫,由于binding和這個update兩個函數(shù)要做的事基本是一樣的,因此在函數(shù)式中只需要寫一份即可。而這個inserted就是為了解決指令綁定完元素,但是元素還在內(nèi)存中,還沒有應(yīng)用到頁面上而出現(xiàn)的問題。

2.2.3,全局指令

上面兩個講的主要是在vue實例的局部指令,如果多個實例都需要使用這個指令的話,那么就可以定義成全局指令。

函數(shù)式全局指令

//Vue.directive(指令名,回調(diào)函數(shù))
Vue.directives("big",function(element,binding){
   //修改元素里面的值
   element.innerText = binding.value * 10;
   console.log(element,binding)
)

對象式全局指令

//Vue.directive(指令名,配置對象)
Vue.directives("fbind",fbind:{
    //指令與元素成功綁定時
    bind(element,binding){
        element.value = binding.value * 10
    },
    //指令所在元素被插入頁面時
    inserted(element,binding){
        element.focus();
    },
    //指令所在的模板被重新解析時被調(diào)用 
    update(element,binding){
        element.value = binding.value * 10
    }
})

這樣就可以實現(xiàn)全局的指令配置了,其底層原理和過濾器一樣。

到此這篇關(guān)于vue的表單數(shù)據(jù)收集,基本指令和自定義指令的文章就介紹到這了,更多相關(guān)vue基本指令和自定義指令內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • element-ui封裝一個Table模板組件的示例

    element-ui封裝一個Table模板組件的示例

    這篇文章主要介紹了element-ui封裝一個Table模板組件的示例,幫助大家更好的理解和學(xué)習vue框架的使用,感興趣的朋友可以了解下
    2021-01-01
  • Vue項目中引入ECharts的教程詳解

    Vue項目中引入ECharts的教程詳解

    ECharts是一個強大的畫圖插件,在vue項目中,我們常??梢砸肊charts來完成完成一些圖表的繪制,本文就來和大家介紹一下如何在Vue項目中引入ECharts吧
    2023-03-03
  • vue-dialog的彈出層組件

    vue-dialog的彈出層組件

    這篇文章主要為大家詳細介紹了vue-dialog的彈出層組件,可以通過npm引用的組件,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • vuejs中使用mixin局部混入/全局混入的方法詳解

    vuejs中使用mixin局部混入/全局混入的方法詳解

    混入可以省很多代碼(高類聚低耦合),還方便維護,下面這篇文章主要給大家介紹了關(guān)于vuejs中使用mixin局部混入/全局混入的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-05-05
  • 如何使用Vue+Element做個個人中心

    如何使用Vue+Element做個個人中心

    我們在做了用戶登錄后,就會讓用戶跳轉(zhuǎn)到個人中心,下面這篇文章主要給大家介紹了關(guān)于如何使用Vue+Element做個個人中心的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-06-06
  • vue webpack重寫cookie路徑的方法

    vue webpack重寫cookie路徑的方法

    webpack提供的反向代理服務(wù)器在開發(fā)階段非常方便,幾行簡單的代碼配置就可以使用反向代理功能,包括路徑重寫、cookie處理等。這篇文章主要介紹了vue webpack重寫cookie路徑,需要的朋友可以參考下
    2019-07-07
  • vue使用 better-scroll的參數(shù)和方法詳解

    vue使用 better-scroll的參數(shù)和方法詳解

    這篇文章主要介紹了vue使用 better-scroll的參數(shù)和方法詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • Vue3+TS+Vant3+Pinia(H5端)配置教程詳解

    Vue3+TS+Vant3+Pinia(H5端)配置教程詳解

    這篇文章主要介紹了Vue3+TS+Vant3+Pinia(H5端)配置教程詳解,需要的朋友可以參考下
    2023-01-01
  • Vue3源碼分析偵聽器watch的實現(xiàn)原理

    Vue3源碼分析偵聽器watch的實現(xiàn)原理

    watch?的本質(zhì)就是觀測一個響應(yīng)式數(shù)據(jù),當數(shù)據(jù)發(fā)生變化時通知并執(zhí)行相應(yīng)的回調(diào)函數(shù)。watch的實現(xiàn)利用了effect?和?options.scheduler?選項,這篇文章主要介紹了Vue3源碼分析偵聽器watch的實現(xiàn)原理,需要的朋友可以參考下
    2022-08-08
  • VueJS實現(xiàn)用戶管理系統(tǒng)

    VueJS實現(xiàn)用戶管理系統(tǒng)

    這篇文章主要為大家詳細介紹了VueJS實現(xiàn)用戶管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05

最新評論