前端Vue select下拉框使用以及监听事件详解

 更新时间:2024年03月01日 11:27:55   作者:A乐神  
由于前端项目使用的是Vue.js和bootstrap整合开发,中间用到了select下拉框,这篇文章主要给大家介绍了关于前端Vue select下拉框使用以及监听事件的相关资料,需要的朋友可以参考下

简介

在 Vue 中,下拉框通常通过 <select> 元素与一系列的 <option> 元素来创建。Vue 的数据绑定和指令(如 v-model 和 v-for)可以使创建动态下拉框变得非常简单和灵活。下面详细介绍如何在 Vue 中使用下拉框。

使用详解

下拉框的基本 HTML 结构是由 <select> 元素包围一组 <option> 元素构成。

在 Vue 中,v-model 指令用于创建双向数据绑定。将 v-model 绑定到 <select> 元素上,可以轻松地获取或设置下拉框的选中值。

使用 v-for 指令可以动态生成下拉框的选项。这对于选项数据来自数组或对象时特别有用。

演示示例

做一个下拉框,接口返回信息key值是1、2、3一直到五,value是1分、2分一直到5分,下拉显示vale值,示例效果如下图

<template>
  <!--div独占一行-->
    <div class="dropdown-container">
      <span>评分:</span>
      <select v-model="selectedNumber" class="dropdown">
        <option v-for="option in options" :key="option.value" :value="option.value">
          {{ option.label }}
        </option>
      </select>
      (默认满分5分)
    </div>
</template>

<script>
export default {
  data() {
    return {
      selectedValue: 5, // 用于接口调用的实际值
      options: [ // 下拉框的选项,模拟接口返回的值,包含显示的标签和实际的值
        { label: '1分', value: 1 },
        { label: '2分', value: 2 },
        { label: '3分', value: 3 },
        { label: '4分', value: 4 },
        { label: '5分', value: 5 }
      ]
    };
  },
  methods: {
    // 你可以在这里添加一个方法来处理选项选择后的操作,例如调用接口
    handleSelection() {
      // 使用 this.selectedValue 作为调用接口的参数
      console.log("Selected value for API call:", this.selectedValue);
      // 这里添加调用接口的代码
    }
  },
  watch: {
    // 监听 selectedValue 的变化,以便在值改变时执行某些操作
    selectedValue(newValue) {
      this.handleSelection();
    }
  }
};
</script>

<style>
  .dropdown-container{
    display: block;
    margin-top: 20px;/*外边距20px,做到独占一行 */
  }

  .dropdown {
    width: 25%;
  }
</style>

:key="option.value" :value="option.value" 区别

:key="option.value":这个绑定在使用 v-for 创建列表时为 Vue 提供了一个唯一的标识符,帮助 Vue 追踪列表中每个节点的身份,从而重用和重新排序现有元素。对于 <option> 元素来说,使用 :key 并不是必须的,因为 <option> 元素通常不涉及到复杂的更新和重用逻辑。然而,如果你的下拉选项可能会动态变化(比如基于另一个选择动态更新),使用 :key 可以帮助 Vue 更高效地处理这些变化。

:value="option.value":这个绑定用于设置每个下拉选项的值。当你选择一个选项时,这个值会被绑定到 v-model 指定的变量上。如果你的下拉列表中的每个选项都对应一个特定的值,并且你需要在选择选项时获取这个值(例如,存储在数据库中的 ID),那么使用 :value 绑定是非常有用的。如果你没有指定 :value,那么选中的 <option> 的内容(即它的文本节点)将作为选中值。

监听事件

上面代码示例中watch事件就是监听,通过这种方式,你可以在用户选择一个新的选项时执行一些操作,如调用一个方法或触发一个事件。当然你也可以使用 @change 事件监听器来响应下拉框选项的变化:

<template>
  <select v-model="selectedOption" @change="handleChange">
    <option v-for="option in options" :key="option.value" :value="option.value">
      {{ option.text }}
    </option>
  </select>
</template>

<script>
export default {
  data() {
    return {
      selectedOption: '',
      options: [ /* 选项数据 */ ]
    };
  },
  methods: {
    handleChange(event) {
      // 处理选项变化
      console.log("Selected option changed to:", this.selectedOption);
    }
  }
};
</script>

附:VUE select下拉框点击事件没有触发的问题

         <Card>
          <Select v-model="typeSelect" style="width:150px;float: right;z-index:999;position: relative" placeholder="请选择指标" @click="changeType()">
            <Option v-for="type in typeArray" :value="type.value" :key="type.label">{{ type.label }}</Option>
          </Select>
          <chart-card :stats-data="playTypePie"></chart-card>
        </Card>
    changeType:function (){
      console.log('您选择了', this.typeSelect)
    },

在点击选择数据类型的时候发现无法触发changeType().

@click="getDivision()"换成@click.native="getDivision()"就可以了 

给vue组件绑定事件时候,必须加上native ,不然不会生效(监听根元素的原生事件,使用 .native 修饰符)

总结 

到此这篇关于前端Vue select下拉框使用以及监听事件详解的文章就介绍到这了,更多相关Vue select下拉框监听内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue的keep-alive中使用EventBus的方法

    vue的keep-alive中使用EventBus的方法

    keep-alive是Vue提供的一个抽象组件,用来对组件进行缓存,从而节省性能,由于是一个抽象组件,所以在页面渲染完毕后不会被渲染成一个DOM元素。这篇文章主要介绍了vue的keep-alive中使用EventBus的方法,需要的朋友可以参考下
    2019-04-04
  • vue如何把字符串中的所有@内容,替换成带标签的

    vue如何把字符串中的所有@内容,替换成带标签的

    这篇文章主要介绍了vue如何把字符串中的所有@内容,替换成带标签的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • Vue使用vue-recoure + http-proxy-middleware + vuex配合promise实现基本的跨域请求封装

    Vue使用vue-recoure + http-proxy-middleware + vuex配合promise实现基本

    这篇文章主要介绍了Vue使用vue-recoure + http-proxy-middleware + vuex配合promise实现基本的跨域请求封装问题,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-10-10
  • vue2 中使用 render 函数编写组件的方式

    vue2 中使用 render 函数编写组件的方式

    vue提供了声明式编写UI的方式,即vue提供了对DOM进行描述的方式,有两种描述DOM的方式即模板和render 函数,本文通过示例代码介绍vue2 中使用 render 函数编写组件的方式,感兴趣的朋友跟随小编一起看看吧
    2024-06-06
  • 一文带你了解Vue3中toRef和toRefs的用法

    一文带你了解Vue3中toRef和toRefs的用法

    Vue3中toRef、toRefs都是与响应式数据相关的,本文主要来给大家讲解一下Vue3中的toRef和toRefs的使用,感兴趣的朋友跟随小编一起看看吧
    2023-01-01
  • vue axios封装httpjs,接口公用配置拦截操作

    vue axios封装httpjs,接口公用配置拦截操作

    这篇文章主要介绍了vue axios封装httpjs,接口公用配置拦截操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • 在vue中实现表单验证码与滑动验证功能的代码详解

    在vue中实现表单验证码与滑动验证功能的代码详解

    在Web应用程序中,表单验证码和滑动验证是常见的安全机制,用于防止恶意攻击和机器人攻击,本文将介绍如何使用Vue和vue-verify-code库来实现表单验证码和滑动验证功能,需要的朋友可以参考下
    2023-06-06
  • vue中mint-ui环境搭建详细介绍

    vue中mint-ui环境搭建详细介绍

    这篇文章主要介绍了vue中mint-ui环境搭建详细介绍的相关资料,需要的朋友可以参考下
    2017-04-04
  • vue.js实现含搜索的多种复选框(附源码)

    vue.js实现含搜索的多种复选框(附源码)

    这篇文章主要给大家介绍了利用vue.js实现含搜索的多种复选框的相关资料,文中给出了简单的介绍,但提供了完整的实例源码供大家下载学习,相信对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-03-03
  • Vue应用部署到服务器的正确方式

    Vue应用部署到服务器的正确方式

    本篇文章主要介绍了详解Vue应用部署到服务器的正确方式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-07-07

最新评论