如何在不使用 eval() 的情况下获得在 Backbone.js 中执行不同操作的链接?

发布于 2024-12-16 22:06:39 字数 272 浏览 0 评论 0 原文

我有一些链接,我想根据链接执行不同的操作。因此我有一个数据结构:

var data = [{"name":"foo", "onClick":"baz()"}, {"name":"bar", "onClick":"bam()"}];

目前,在视图中我有一个运行函数,它接受该项目并执行 eval(item.onClick) ,并且它有效,只是感觉像是一个安全漏洞。 我可以在渲染视图时将 onClick 放入 html 中,但这感觉不对。

有谁知道有什么方法可以做到这一点?

I have links which I want to do different things depending on the link. Therefore I have a datastructure:

var data = [{"name":"foo", "onClick":"baz()"}, {"name":"bar", "onClick":"bam()"}];

Currently, in the view i have a function run which takes the item and does eval(item.onClick), and that works, just it feels like a security hole.
I could put the onClick into the html when rendering the view, but that feels wrong.

Does anyone know of a way to do this?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

战皆罪 2024-12-23 22:06:39

您可以在数据中嵌入函数

var data = [{"name":"foo", "onClick":baz}, {"name":"bar", "onClick":bam}];
item.onClick();

您可以查看 这里了解更多有用的内容

You can embed function in the data

var data = [{"name":"foo", "onClick":baz}, {"name":"bar", "onClick":bam}];
item.onClick();

You can look here for more helpful stuff how to do it

铜锣湾横着走 2024-12-23 22:06:39

主干视图有一个 delegateEvents 函数

var MyView = Backbone.View.extend({

  events: {
    "click button[name='foo']": "baz",
    "click button[name='bar']": "bam"
  },


  baz: function(){ ... }

  bam: function(){ ... }

Backbone views have a delegateEvents function:

var MyView = Backbone.View.extend({

  events: {
    "click button[name='foo']": "baz",
    "click button[name='bar']": "bam"
  },


  baz: function(){ ... }

  bam: function(){ ... }
度的依靠╰つ 2024-12-23 22:06:39

很简单——即使您没有为函数调用实现对象容器。

function baz(){ 
    ....
}
function bam(){ 
    ....
}

并且,假设您将其作为 JSON 回调:

function jsonCallback(data){
    /*some code*/
    window[data.onClick]();
    /* some more code */
} 

Easy -- even if you don't implement an object container for your function call.

function baz(){ 
    ....
}
function bam(){ 
    ....
}

And, assuming you have this as your JSON callback:

function jsonCallback(data){
    /*some code*/
    window[data.onClick]();
    /* some more code */
} 
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文