温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么在Vue.js中实现一个带下拉选项的输入框

发布时间:2021-04-17 15:44:29 来源:亿速云 阅读:916 作者:Leah 栏目:开发技术

这篇文章将为大家详细讲解有关怎么在Vue.js中实现一个带下拉选项的输入框,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

注册组件

通过将封装好的组件代码复制粘贴来注册全局组件。

设计的时候有考虑到输入框可能存在不同的类型,例如文本输入框,数值输入框,百分数输入框等等。所以在封装的代码中会通过函数 inputRule 来限制输入。限制的方法是利用 Regex 进行过滤。如果有其他类型,也可以通过修改 inputRule 中的过滤条件。

<script type="text/x-template" id="dropdown">     <div class="dropdown" v-if="options">         <!-- Dropdown Input -->         <input  :type="type"                 :disabled="disabled"                 v-model="input_value"                 @focus="showOptions()"                 @blur="exit()"                 @keyup="keyMonitor"                 @input="input_value = inputRule(type)" /> ... </script> <script>     Vue.component('dropdown', {         template: '#dropdown',         props: {             type: String,             options: Array,             disabled: Boolean,             value: String         }, ...         methods: {             inputRule:function(type){                 var value;                 switch(type){                     case 'text':                         value = this.input_value.replace(/[^a-zA-Z0-9]/g,'');                         break;                     case 'number':                         value = this.input_value.replace(/^(?![+-]?\d+(\.\d+)?$)/g,'');                         break;                     case 'percentage':                         value = this.input_value.replace(/[^\d]/g,'');                         value = value > 100 ? '100' : value;                         value = value < 0 ? '0' : value;                         break;                     default:                         console.log("no limitation");                 }                 return value;             }, ... </script>

调用组件

添加自定义标签调用组件。

<dropdown   type = "text"             :options = "text_options"              :value = "text_value"             :disabled = "text_disabled"              @on_change_input_value = "onTextChange"> </dropdown>

传递数据

最后动态绑定数据到父级组件, props 中:

  • type: 输入框的类型,现支持 text, number 和 percentage。

  • options: 输入框下拉列表的选项

  • value: 输入框的值

  • disabled: 是否禁止点击输入框

另外我们还需要在父级实例中定义事情,用于更新输入框的值

on_change_input_value: 更新值

data: function () {     return {         text_value: 'ccc',         text_disabled: false,         text_options: [             { id: 1, name: 'a' },             { id: 2, name: 'bb' },             { id: 3, name: 'ccc' },             { id: 4, name: 'dddd' },             { id: 5, name: 'eeeee' },             { id: 6, name: 'fffff ' },             { id: 7, name: 'gggggg' },             { id: 8, name: 'hhhhhhh' },             { id: 9, name: 'iiiiiiii' },         ],         ...     } }, ... methods: {     onTextChange: function (new_text_value) {         this.text_value = new_text_value;     }, ... },

关于怎么在Vue.js中实现一个带下拉选项的输入框就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI