首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >input.value未定义

input.value未定义
EN

Stack Overflow用户
提问于 2015-10-21 10:35:01
回答 1查看 1.6K关注 0票数 2

我需要验证我自己的一个领域;合法只是数字。

以下是简单的HTML:

代码语言:javascript
复制
<div class="form-group">
    <label for="superficie">Superficie</label>
    <input type="text" class="form-control required-field" data-type="number" name="superficie" />
</div>

这是Jquery:

代码语言:javascript
复制
$('.current .required-field').each(function(index) {
    $(this).keyup(function() {
        var input_type = $(this).data('type');
        validate($(this), input_type);
    });
});

function validate(input, input_type) {
    switch(input_type) {
        case 'number':
            if (input.value != input.value.replace(/[^0-9\.]/g, '')) {
                input.value = input.value.replace(/[^0-9\.]/g, '');
            }
            break;
        }
    }

控制台返回错误:

input.value是未定义的。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-10-21 10:36:03

input变量包含一个没有value属性的jQuery对象。要访问需要使用val()方法的值,或者可以向函数提供本机HTMLElement:

代码语言:javascript
复制
validate(this, input_type);

最后,值得注意的是,您可以简化代码,因为所有这些代码都通过this挂起对元素的引用

代码语言:javascript
复制
$('.current .required-field').keyup(validate);

function validate() {
    var $el = $(this);
    switch ($el.data('type')) {
        case 'number':
            $el.val(function(i, v) {
               return v.replace(/[^0-9\.]/g, '');
            });
            break;
    }
}
票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33257059

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档