当前位置:  开发笔记 > 编程语言 > 正文

嵌入式Ruby的Javascript:如何安全地将ruby值分配给javascript变量

如何解决《嵌入式Ruby的Javascript:如何安全地将ruby值分配给javascript变量》经验,为你挑选了2个好方法。

我在页面的javascript块中有这一行:

res = foo('<%= @ruby_var %>'); 

处理@ruby_var单引号的情况的最佳方法是什么?否则它将破坏JavaScript代码.



1> TFKyle..:

我想我会在@ruby_var上使用ruby JSON库为字符串获取正确的js语法并摆脱'',fex:

res = foo(<%= @ruby_var.to_json %>)

(在要求"json"之后,不完全确定如何在页面中执行此操作,或者如果上面的语法是正确的,因为我没有使用该模板语言)

(另一方面,如果JSON曾经被改变为与js不相容,但是因为有相当数量的代码使用eval()来评估json,我怀疑这种情况很快就会发生)



2> Mike Jarema..:

Rails有一个专门用于此任务的方法,在ActionView :: Helpers :: JavaScriptHelper中找到,名为escape_javascript.

在您的示例中,您将使用以下内容:

res = foo('<%= escape_javascript @ruby_var %>');

或者更好的是,使用j快捷方式:

res = foo('<%= j @ruby_var %>');

推荐阅读
手机用户2402851335
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有