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

Vue設(shè)置select下拉框的默認(rèn)選項(xiàng)詳解(select空白bug解決)

 更新時(shí)間:2022年12月10日 15:29:51   作者:小安駕到  
最近開始學(xué)習(xí)vue,在學(xué)習(xí)的過程中遇到的問題將記錄在這里,下面這篇文章主要給大家介紹了關(guān)于Vue設(shè)置select下拉框的默認(rèn)選項(xiàng)(select空白bug解決)的相關(guān)資料,需要的朋友可以參考下

最近在用vue設(shè)置表單數(shù)據(jù)時(shí)發(fā)現(xiàn)了一個(gè)小問題:用vue動(dòng)態(tài)渲染select下拉框時(shí),select下拉框會(huì)出現(xiàn)空白的bug。

<template>
  <div>
    <select name="art-cate" v-model="select">
        <option disabled selected style="display: block;">請(qǐng)選擇您的科目</option>
        <option v-for="(item,index) in arr " 
                :key="index" 
                :value="item.name">{{item.name}}</option>
    </select>
  </div>
</template>
 
<script>
export default {
    data() {
        return {
            arr: [{ name: '語文' }, { name: '數(shù)學(xué)' }, { name: '英語' }],
            select:''
        }
    }
</script>

Bug如下:

明明有一個(gè)selected的option選項(xiàng),為什么會(huì)是一片空白呢?其實(shí)原因很簡(jiǎn)單,就一句話:<select>的v-model變量是空的。

這句話一出可能很多人都恍然大悟了,v-model指令是雙向數(shù)據(jù)流動(dòng),vue變量沒有值,那么select框當(dāng)然也是空白的嘍。 

可是另一個(gè)問題來了,為什么其他的表單不會(huì)這樣呢?

單選框、多選框和輸入框雖然默認(rèn)都是沒有值的,但是它們沒有值也不會(huì)影響它們的表現(xiàn)形式,因?yàn)樗鼈儽緛砭涂梢允强瞻椎模挥?<select> 標(biāo)簽不行,必須要有一個(gè)值才可以。所以我們可能會(huì)忽略這點(diǎn),忘了給 v-model 綁定的變量賦值,結(jié)果就是select標(biāo)簽是一片空白。

解決方法很簡(jiǎn)單:就是把v-model綁定的變量賦值即可。

select:'請(qǐng)選擇您的科目'  // select是 <select>標(biāo)簽 雙向綁定的變量

到此為止,好像事件已經(jīng)結(jié)束了,bug已經(jīng)沒有了,然鵝還有一個(gè)小問題:

當(dāng)你輸入完全正確的字符串時(shí),select當(dāng)然一切正常,然而如果你輸入的是一些亂七八糟的字符時(shí),select仍然是一片空白。

select:'亂七八糟的sdsdf'

效果圖:

這是因?yàn)閟elect綁定的vue變量必須和option中的value值絕對(duì)對(duì)應(yīng),否則就不會(huì)顯示option的文本元素。

那為什么輸入 "請(qǐng)選擇您的科目" 就能顯示出來呢?我明明沒有給這個(gè)option指定value值啊,

原因是:select的某個(gè)option標(biāo)簽在沒有指定value值時(shí),option默認(rèn)會(huì)把標(biāo)簽內(nèi)的文本內(nèi)容當(dāng)做自己的value值。

所以我們輸入的看似是 "請(qǐng)選擇您的科目" ,實(shí)際上輸入的是 第一個(gè)option的value值,所以select標(biāo)簽就顯示出來第一個(gè)option的文本內(nèi)容啦。

這也會(huì)引出這個(gè)bug的另一個(gè)觸發(fā)方式:當(dāng)我們從后端接收到的value值為undefined時(shí),我們將其渲染到select標(biāo)簽上,也會(huì)引發(fā)<select>標(biāo)簽顯示空白的bug,因?yàn)闆]有哪個(gè)option的value值是undefined的。

但同時(shí),我們也可以利用這個(gè)特性,手動(dòng)的把第一個(gè)option的值設(shè)置為空,那么即使vue變量沒有設(shè)置初識(shí)值,那么也會(huì)顯示出來第一個(gè)option的文本內(nèi)容。

<option value="">請(qǐng)選擇您的科目</option>

此時(shí)即使與<select>綁定的變量為 ' ' ,也能顯示出來這個(gè)option的文本內(nèi)容了。

至此,有關(guān)于vue和select空白的bug就講解完畢咯,總結(jié)如下:

  1. 之所以用v-model綁定的<select>標(biāo)簽顯示空白,是因?yàn)関ue變量 沒有指定默認(rèn)值;其他表單元素不需要指定變量的默認(rèn)值,是因?yàn)樗鼈儽緛砭涂梢允强瞻椎摹?/li>
  2. 解決方法有二:一、設(shè)置變量的默認(rèn)值  二、設(shè)置默認(rèn)的option的value值為空字符串   
  3. 當(dāng)我們給vue變量一個(gè)指定的默認(rèn)值,但該值無法和任何option的value值對(duì)應(yīng)時(shí),<select>標(biāo)簽仍然會(huì)顯示一片空白,與<select>綁定的變量的值,必須要為某個(gè)option的value值才行!因?yàn)橹挥羞@樣,<select>標(biāo)簽才能顯示出option的文本內(nèi)容。
  4. 沒有指定value值的option,其文本內(nèi)容會(huì)自動(dòng)成為這個(gè)option的value值。

總結(jié)

到此這篇關(guān)于Vue設(shè)置select下拉框的默認(rèn)選項(xiàng)的文章就介紹到這了,更多相關(guān)Vue select下拉框默認(rèn)選項(xiàng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 教你使用vue3寫Json-Preview的示例代碼

    教你使用vue3寫Json-Preview的示例代碼

    這篇文章主要介紹了用vue3寫了一個(gè)Json-Preview的相關(guān)知識(shí),引入后直接<json-preview?v-model="jsonData"></json-preview>就可以使用了,本文通過示例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • vue?element?el-select下拉滾動(dòng)加載的方法

    vue?element?el-select下拉滾動(dòng)加載的方法

    很多朋友都遇到這樣一個(gè)問題在使用vue+element的el-select下拉框加載返回?cái)?shù)據(jù)太多時(shí),會(huì)造成卡頓,用戶體驗(yàn)欠佳,這篇文章主要介紹了vue?element?el-select下拉滾動(dòng)加載方法,需要的朋友可以參考下
    2022-11-11
  • 在vue和element-ui的table中實(shí)現(xiàn)分頁復(fù)選功能

    在vue和element-ui的table中實(shí)現(xiàn)分頁復(fù)選功能

    這篇文章主要介紹了在vue和element-ui的table中實(shí)現(xiàn)分頁復(fù)選功能,本文代碼結(jié)合圖文的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-12-12
  • Vue開發(fā)中整合axios的文件整理

    Vue開發(fā)中整合axios的文件整理

    這篇文章主要給大家整理了在Vue開發(fā)中整合axios要用到的文件,在vue開發(fā)中,不可避免要整合axios,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面來一起看看吧。
    2017-04-04
  • 解決VUE項(xiàng)目使用Element-ui 下拉組件的驗(yàn)證失效問題

    解決VUE項(xiàng)目使用Element-ui 下拉組件的驗(yàn)證失效問題

    這篇文章主要介紹了解決VUE項(xiàng)目使用Element-ui 下拉組件的驗(yàn)證失效問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 解決vue單頁面應(yīng)用進(jìn)入頁面加載所有 js 的問題

    解決vue單頁面應(yīng)用進(jìn)入頁面加載所有 js 的問題

    這篇文章主要介紹了解決vue單頁面應(yīng)用進(jìn)入頁面加載所有 js 的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • 對(duì)Vue- 動(dòng)態(tài)元素屬性及v-bind和v-model的區(qū)別詳解

    對(duì)Vue- 動(dòng)態(tài)元素屬性及v-bind和v-model的區(qū)別詳解

    今天小編就為大家分享一篇對(duì)Vue- 動(dòng)態(tài)元素屬性及v-bind和v-model的區(qū)別詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • vue element el-form 多級(jí)嵌套驗(yàn)證的實(shí)現(xiàn)示例

    vue element el-form 多級(jí)嵌套驗(yàn)證的實(shí)現(xiàn)示例

    本文主要介紹了vue element el-form 多級(jí)嵌套驗(yàn)證的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • vue實(shí)現(xiàn)修改圖片后實(shí)時(shí)更新

    vue實(shí)現(xiàn)修改圖片后實(shí)時(shí)更新

    今天小編就為大家分享一篇vue實(shí)現(xiàn)修改圖片后實(shí)時(shí)更新,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue中定義的data為什么是函數(shù)

    vue中定義的data為什么是函數(shù)

    這篇文章主要介紹了vue中定義的data為什么是函數(shù),vue中已經(jīng)幫我們控制臺(tái)輸出警告,并且不會(huì)讓組件中的data合并到options中去,那么,很友好的處理了開發(fā)者的強(qiáng)行將data寫成對(duì)象的可能性,需要的朋友可以參考下
    2022-09-09

最新評(píng)論