内容简介:由Vue实现限制文本框输入长度引发的思考
最近,公司产品线改成使用Vue主线开发,前几天有一个需求:一个标题输入文本框,需要限制其长度。google,百度搜索答案都不满意,现总结并扩展一下,希望能给Vue使用者带来一些帮助。
过滤器
针对这类限制输入的需求,很容易想到的是使用Vue过滤器,如:
Vue.filter('sliceString', function(str, start, length) { return str.slice(start, length); }); // 组件模板中使用如下: <template> <input type="text" v-model="title | sliceString 0 10"> </template>
但是需要注意的是Vue 2.x版本已经移除了内置过滤器,不支持组件内过滤器,只能全局注册,至于为什么要这样做,我并不清楚。
watch监听
除了过滤器,还有一种简便的方式,即使用 Vue
组件的 watch
属性,监听属性或表达式,比如,我们需要控制标题字数在12字以内,在某组件内定义如下代码:
data() { return { title: '', titleMaxLength: 12 }; }, watch: { title() { if (this.title.length > this.titleMaxLength) { this.title = String(this.title).slice(0, this.titleMaxLength); } } }
在模板中使用方式如下:
<input type="text" v-model="title">
这种方式比较直接,而且不需要考虑 Vue
版本,但是复用性差;如果在多组件内有共同需求,可以使用全局过滤器或者mixins方式定义。
自定义指令
要说可拓展性最强的方式,当然还是自定义指令,自定义指令提供诸多组件元素生命周期函数:
// 注册 Vue.directive('my-directive', { bind: function () {}, inserted: function () {}, update: function () {}, componentUpdated: function () {}, unbind: function () {} }); // 注册(传入一个简单的指令函数) Vue.directive('my-directive', function () { // 这里将会被 `bind` 和 `update` 调用 });
如果使用指令实现上述例子,可以使用全局注册,也可以局部组件内定义指令,这里以组件内定义为例,代码如下:
directives: { sliceString: { update(el, binding) { if (el.value.length > binding.value) { el.value = el.value.slice(0, binding.value); } } } }
在模板中使用方式如下:
<input type="text" v-sliceString="titleMaxLength" v-model="title">
除了例子中可以限制输入长度,还可以实现很多需求,如过滤屏蔽某些输入,对某些输入数据做验证等等,而且实现方式也多种多样,各有千秋,可以根据需求衡量,选择。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 由Vue实现限制文本框输入长度引发的思考
- c# – 如何限制MVC中文本框中的字符长度?
- memcached对key和value的限制 memcached的key最大长度和Value最大长度
- protobuf可变长度原理
- Haskell长度图说明?
- perl – 截断stdin行长度?
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据挖掘导论
(美)Pang-Ning Tan、Michael Steinbach、Vipin Kumar / 机械工业出版社 / 2010-9 / 59.00元
本书全面介绍了数据挖掘的理论和方法,着重介绍如何用数据挖掘知识解决各种实际问题,涉及学科领域众多,适用面广。 书中涵盖5个主题:数据、分类、关联分析、聚类和异常检测。除异常检测外,每个主题都包含两章:前面一章讲述基本概念、代表性算法和评估技术,后面一章较深入地讨论高级概念和算法。目的是使读者在透彻地理解数据挖掘基础的同时,还能了解更多重要的高级主题。 本书特色 ·包含大量的图表、......一起来看看 《数据挖掘导论》 这本书的介绍吧!
CSS 压缩/解压工具
在线压缩/解压 CSS 代码
UNIX 时间戳转换
UNIX 时间戳转换