2011-01-31 24 views
9

即时通讯使用validates_format_of方法检查电子邮件格式:使用livevalidation插件来验证表单,所以在我的代码即时得到如何红宝石正则表达式转换为JavaScript的? - :和Rails 3.0.3

validates_format_of :email, :with => /^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/i 

还林:

(I-MX ..?)
(?i-mx:^([^@\\s]+)@((?:[-a-z0-9]+\\.)+[a-z]{2,})$) 

的Javascript不能阅读本正则表达式。如何或在哪里我可以改变这个正则表达式是为原文:

/^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/i 

+0

此问题的相关搜索结果[可在此处找到](https://www.google.com/#hl=zh-CN&safe=active&sclient=psy-ab&q=(convert%7Ctranslate)+ ruby​​ + regex + to + javascript&oq =(转化%7Ctranslate)+红宝石+ +正则表达式到+的javascript&gs_l = serp.3 ... 6611.13840.0.14133.12.12.0.0.0.0.123.1024.9j3.12.0.les%3B..0.0 ... 1c.1.4。 PSY-ab.OIu4b055si4&PBX = 1&BAV = on.2,or.r_gc.r_pw.r_cp.r_qf。&FP = 50b26647ad5972f8&BIW = 1366&波黑= 639)。 – 2013-02-20 15:38:37

回答

1

原因是你正在使用.to_s而不是.inspect来转换你的正则表达式。在你看来,你需要做的是使用.inspect来获得正确的格式。这里是一个要解释这个问题的一些示例代码:

email = /^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/i 
email.to_s #"(?i-mx:^([^@\\s]+)@((?:[-a-z0-9]+\\.)+[a-z]{2,})$)" 
email.inspect #"/^([^@\\s]+)@((?:[-a-z0-9]+\\.)+[a-z]{2,})$/i" 

所以,在你的JavaScript观点做这样的事情来得到你想要的实际字符串表示:

<%= email.inspect %> 
7

Ruby和JavaScript的正则表达式由具有不同能力的不同引擎解析和执行。正因为如此,Ruby和JavaScript正则表达式具有稍微不兼容的细微差别。如果您注意到它们没有直接翻译,那么您仍然可以在JavaScript中表示简单的Ruby正则表达式。

这里的what client side validations does

class Regexp 
    def to_javascript 
    Regexp.new(inspect.sub('\\A','^').sub('\\Z','$').sub('\\z','$').sub(/^\//,'').sub(/\/[a-z]*$/,'').gsub(/\(\?#.+\)/, '').gsub(/\(\?-\w+:/,'('), self.options).inspect 
    end 
end 

最近addition of the routes inspector to rails需要a similar approach,甚至更好,因为它避免了猴子补丁:

def json_regexp(regexp) 
    str = regexp.inspect. 
     sub('\\A' , '^'). 
     sub('\\Z' , '$'). 
     sub('\\z' , '$'). 
     sub(/^\// , ''). 
     sub(/\/[a-z]*$/ , ''). 
     gsub(/\(\?#.+\)/ , ''). 
     gsub(/\(\?-\w+:/ , '('). 
     gsub(/\s/ , '') 
    Regexp.new(str).source 
end 

然后将这些媒体插入JavaScript代码,使用这样的:

var regexp = #{/^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/i.to_javascript}; 
+1

转换`/[email protected]+\..+/i`会导致双重转义,即它不起作用。 – 2017-06-25 10:58:52