Vue 将输入框的输入的小写自动转大写(使用 v-model 时采取另一种方式)

本文介绍了如何在Vue项目中,使用v-model时将输入框内的小写字母自动转换为大写。由于直接结合filter会引发错误,所以建议通过计算属性的方式来实现这一功能。

输入框中小写字母自动转换为大写

网站地址:我的个人vue+element ui demo网站    

github地址:yuleGH github

  • 过滤器实现

<html>

<head>
    <title>测试</title>
</head>
<body>
<div id="app">

    <input id="val1" v-model="value1">
    <br/>
    显示小写转大写 : {{ value1 | upper}}

</div>
<!-- 引入组件库 -->
<script type="text/javascript" src="${ctx}/static/common/js/vue.js"></script>

<script type="text/javascript">

    new Vue({
        el: "#app",
        data: {
            value1: ""
        },
        filters: {
            upper: function (value) {
                if (!value) return '';
                value = value.toString();
                return value.toUpperCase();
            }
        }
    });
</script>

</body>

</html>
  • v-model 中的实现

如果想要在使用 v-model 时,也要大写转小写,就不能喝 filter 结合,因为这会报错,这时应该换换种实现方式。可以采用计算属性

<html>

<head>
    <title>测试</title>
</head>
<body>
<div id="app">
    输入框中直接输入小写转大写:
    <input v-model="value2Computed">
</div>
<!-- 引入组件库 -->
<script type="text/javascript" src="${ctx}/static/common/js/vue.js"></script>

<script type="text/javascript">

    new Vue({
        el: "#app",
        data: {
            value2: ""
        },
        computed : {
            value2Computed : {
                get: function(){
                    return this.value2;
                },
                set : function(val){
                    this.value2 = val.toUpperCase();
                }
            }
        }
    });
</script>

</body>

</html>

 

 

 

 

 

 

https://www.cnblogs.com/yuxiaole/p/9289205.html

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_格鲁特宝宝

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值