首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Javascript restrict()用于过滤输入

Javascript restrict()用于过滤输入
EN

Stack Overflow用户
提问于 2018-02-26 12:57:10
回答 1查看 102关注 0票数 1

我环顾四周,真的没有找到任何关于这个函数的东西,也没有找到我想要用它做什么。

在注册表中,我有以下内容:

代码语言:javascript
复制
<label>*Email
<input type="email" name="email" id="email" minlength="5" maxlength="40" onfocus="emptyElement('status')" onkeyup="restrict('email')"/>
</label>

在javascript文件中,我输入了:

代码语言:javascript
复制
function restrict(elem){
            var tf = _(elem);
            var rx = new RegExp;
            if(elem === "email"){
                rx = /[' "]/gi;
            } else if(elem === "username"){
                rx = /[^a-z0-9]/gi;
            }
            tf.value = tf.value.replace(rx, "");
        }

我尝试做的是将此字段和用户名字段中的内容限制为上面提到的限制。

来自控制台的错误是: TypeError: tf.value.replace不是一个函数。

感谢任何人可能有的任何提示!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-02-26 13:29:46

该错误消息意味着tf.value上不存在函数String.replace。这是因为tf.value不是字符串。要弄清楚是怎么回事,您可以查看jQuery文档,了解它们希望您如何对元素的值执行getset操作。

查看这两个链接,您可以看到设置和获取元素值的正确方法如下所示:

代码语言:javascript
复制
// Set    
$(element).val("value");

// Get
$(element).val();

你的代码还有一些其他的问题。首先,jQuery通常使用$作为前缀。其次,jQuery在查找元素时使用CSS selectors,因此您需要在任何id前加上#,以便根据id查找元素。你的代码应该看起来像这样:

代码语言:javascript
复制
function restrict(elem){
  var tf = $('#' + elem);
  var rx = new RegExp();
  if(elem === "email"){
    rx = /[' "]/gi;
  } else if(elem === "username"){
    rx = /[^a-z0-9]/gi;
  }
  tf.val(tf.val().replace(rx, ""));
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48981676

复制
相关文章

相似问题

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