Vue中select下拉框的默认选中项的三种情况解读

 更新时间:2023年05月11日 14:58:19   作者:July++  
这篇文章主要介绍了Vue中select下拉框的默认选中项的三种情况解读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

vue select下拉框的默认选中项的三种情况

在Vue中 使用select下拉框 主要靠的是 v-model 来绑定选项 option 的 value 值。

select下拉框在界面的展示,我们都希望看到框中有一个值 而不是空白,比如显示 “请选择” 或者 “全部” 的默认值。

先来看效果图

select默认选中项

关于select选项的写法 有三种情况

  • ①.写在HTML中
  • ②.写在JS一个数组中
  • ③.通过接口去获取得到

我们直接上代码:

第一种是option的值写在HTML中

  <div id="app">
     <select name="status" id="status" v-model="selected">
         <option value="">请选择</option>
         <option value="1">未处理</option>
         <option value="2">处理中</option>
          <option value="3">处理完成</option>
     </select>
   </div>
<script>
   new Vue({
       el:'#app',
       data:{
              selected:''  
              //默认选中项的value值是什么  就给绑定的属性什么值  这里默认选中项请选择的value值是空  我们就给绑定的属性 select 一个空值
       },
   })
    </script>

第二种是option 选项内容写在JS中的

通过v-for来遍历的:

<body>
    <div id="app">
     <select name="status" id="status" v-model="selected">
            <option :value="item.statusId" v-for="(item,index) in statusArr">{{item.statusVal}}</option>
     </select>
   </div>
</body>
<script>
   new Vue({
       el:'#app',
       data:{
              statusArr:[
                  {
                      statusId:'0',
                      statusVal:'请选择'
                  },
                  {
                      statusId:'1',
                      statusVal:'未处理'
                  },
                  {
                      statusId:'2',
                      statusVal:'处理中'
                  },
                  {
                      statusId:'3',
                      statusVal:'处理完成'
                  },
              ],
              selected:''
       },
       created(){
           // 在组件创建之后,把默认选中项的value值赋给绑定的属性
           //如果没有这句代码,select中初始化会是空白的,默认选中就无法实现
         this.selected = this.statusArr[0].statusId;
       }
   })
    </script>

第三种是option 选项内容

通过接口去获取 但是接口里没有默认选中项怎么办呢?看代码

<body>
    <div id="app">
     <select name="status" id="status" v-model="selected">
         <!-- 由于从接口获取的select的下拉值没有‘请选择',所以我们要自己写一个 -->
        <option value="">请选择</option> 
        <option :value="item.statusId" v-for="(item,index) in statusArr">{{item.statusVal}}</option>
     </select>
   </div>
</body>
<script>
   new Vue({
       el:'#app',
       data:{
              statusArr:[], //用来接收从接口里获取出来的select下拉框里的值
              selected:''
       },
       getSelectInfo(){
           var url = "../monitor_admin_front/device/status"; //接口地址
           axios.get(url)
           .then(response => {
              if(response.data.retCode == 0){
                 this.statusArr = response.data.data; //将获取出来的数据赋给定义的数组 以便于去循环遍历
              }
           }) 
       },
       created(){
         this.getSelectInfo();
       }
   })
    </script>

vue中select默认选中下拉选项第一条(举例iview AutoComplete组件)

html中

  • 静态

给对应option元素直接添加selected属性

<select> 
	<option value="0">one</option> 
	<option value="1">two</option> 
	<option value="2" selected>three</option> 
</select>
  • 动态

option加载完成后给对应元素添加selected属性

$("option")[2].prop("selected","selected");

vue中

选中第一项同时并改变select绑定的value(正常业务)

<template>
	<select v-model="value"> 
		<option value="0">New York</option> 
		<option value="1">London</option>
		<option value="2">Sydney</option>
		<option value="3">Ottawa</option>
	</select>
</template>
export default {
	data () {
    	return {
    		value: '0'	
    	}
    }
}

可模糊匹配,select输入模糊匹配,默认选中下拉选项中第一项,但select绑定的value不变,即下图所示:

可模糊匹配,select输入模糊匹配,默认选中下拉选项中第一项,但select绑定的value不变

我的做法是

1.输入值改变时,监听change事件引起下拉选项的发生改变

2.判断筛选后的下拉选项Dom元素中没有选中项,为第一项New York添加选中样式;若有选中项则不操作

3.监听回车事件,如此时有回车事件,判断下拉选项Dom中第一项有选中样式则将value的值变更为选项中第一项的值,即this.value = ‘New York’,并将下拉选项框隐藏

4.我的实际列子是使用iviewUI中的AutoComplete组件做的(简单举个例子,只提供参考)

<template>
  <div id="search-input-component">
    <AutoComplete
      v-model="value"
      type="text"
      @keydown.enter.native.prevent="enterEvent"
      @on-change="change"
    >
      <Option
        v-for="item in changeList"
        :value="item.value"
        :key="item.value"
      >
        {{item.name}}
      </Option>
    </AutoComplete>
  </div>
</template>
<script>
export default {
  data () {
    return {
      value: '', // AutoComplete绑定的值
      valueLists: [
        // { value: '选项值', name: '选项名' }
      ], // 全部拉选项列表
      changeList: [] // 实时模糊匹配的下拉选项列表
    }
  },
  created () {
    this.getAllList()
  },
  methods: {
    // 获取所有下拉选项
    getAllList () {
      // ...Data
      this.valueLists = Data
      this.changeList = Data
    },
    // 输入change事件
    change (val) {
      // 模糊匹配逻辑,重新生成下拉选项列表
      this.changeList = []
      this.valueLists.map(item => {
        if (item.toUpperCase().indexOf(val.toUpperCase()) !== -1) {
          this.changeList.push(item)
        }
      })
      this.$nextTick(() => {
        // 下拉框中所有选项的Dom
        const ele = document.querySelectorAll('#search-input-component .ivu-select-dropdown.ivu-auto-complete .ivu-select-dropdown-list .ivu-select-item')
        let hasFocus = false // 初始赋值没有选中项
        for(let i=0; i < ele.length; i++) {
          // 判断有选中项
          if (ele[i].className.indexOf('ivu-select-item-focus') > -1) {
            hasFocus = true
            break
          }
        }
        // 判断没有选中项,则选中第一项(添加选中样式)
        if (!hasFocus && (ele[0].className.indexOf('ivu-select-item-focus') === -1)) {
          ele[0].classList += ' ivu-select-item-focus'
        }
      })
    },
    // 回车事件
    enterEvent (card, isUpdate) {
      const selectDom = document.querySelector('#search-input-component .ivu-select-dropdown.ivu-auto-complete')
      // 下拉选项有匹配到数据 并且 下拉选项没有隐藏
      if (this.changeList.length && !selectDom.style.display) {
        // 下拉框中所有选项的Dom
        const items = document.querySelectorAll('#search-input-component .ivu-select-dropdown.ivu-auto-complete .ivu-select-dropdown-list .ivu-select-item')
        let hasFocus = false // 初始赋值没有选中项
        for(let i=0; i < items.length; i++) {
          // 判断有选中项
          if (items[i].className.indexOf('ivu-select-item-focus') > -1) {
            hasFocus = true
            break
          }
        }
        // 判断没有选中项,则选中第一项
        if (!hasFocus) {
          this.value = this.changeList[0].cardId
        }
        selectDom.style.display = 'none' // 隐藏下拉框
      }
    }
  }
}
</script>

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Vue3如何处理异步任务轮询

    Vue3如何处理异步任务轮询

    在许多应用程序中,我们经常需要执行定期的异步任务轮询,本文就介绍了Vue3如何处理异步任务轮询,感兴趣的可以了解一下
    2023-05-05
  • 详解vue中在循环中使用@mouseenter 和 @mouseleave事件闪烁问题解决方法

    详解vue中在循环中使用@mouseenter 和 @mouseleave事件闪烁问题解决方法

    这篇文章主要介绍了详解vue中在循环中使用@mouseenter 和 @mouseleave事件闪烁问题解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • Vue中瀑布流布局与图片加载优化的实现

    Vue中瀑布流布局与图片加载优化的实现

    本文主要介绍了Vue中瀑布流布局与图片加载优化的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • vue中子组件的methods中获取到props中的值方法

    vue中子组件的methods中获取到props中的值方法

    今天小编就为大家分享一篇vue中子组件的methods中获取到props中的值方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-08-08
  • Vue PC端实现扫码登录功能示例代码

    Vue PC端实现扫码登录功能示例代码

    目前大多数PC端应用都有配套的移动端APP,如微信,淘宝等,通过使用手机APP上的扫一扫功能去扫页面二维码图片进行登录,使得用户登录操作更方便,安全,快捷,这篇文章主要介绍了Vue PC端如何实现扫码登录功能,需要的朋友可以参考下
    2023-01-01
  • vue实现移动端input上传视频、音频

    vue实现移动端input上传视频、音频

    这篇文章主要为大家详细介绍了vue实现移动端input上传视频、音频,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • 在vite项目中使用@进行文件的引入方式

    在vite项目中使用@进行文件的引入方式

    这篇文章主要介绍了在vite项目中使用@进行文件的引入方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • 深度剖析 Vue3 在浏览器的运行原理

    深度剖析 Vue3 在浏览器的运行原理

    这篇文章主要介绍了深度剖析Vue3在浏览器的运行原理,文章通过围绕主题展开相关详细介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09
  • 解决VUE中document.body.scrollTop为0的问题

    解决VUE中document.body.scrollTop为0的问题

    今天小编就为大家分享一篇解决VUE中document.body.scrollTop为0的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • Vue中避免滥用this去读取data中数据

    Vue中避免滥用this去读取data中数据

    这篇文章主要介绍了Vue中避免滥用this去读取data中数据的的相关资料,帮助大家更好的理解和学习使用vue框架,感兴趣的朋友可以了解下
    2021-03-03

最新评论