Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Javascript variable in razor ActionLink

var boxIdValue = 233;
var result = title + '<br/>@Html.ActionLink("Detail", "Show", "Boxes", new{boxId=233}, null)';

When I hardcode boxId then it works. But when I write:

var result = title + '<br/>@Html.ActionLink("Detail", "Show", "Boxes", new{boxId=boxIdValue}, null)';

It doesn't. Is it possible to mix javascript var and razor in this way?

like image 502
1110 Avatar asked Mar 17 '12 15:03

1110


1 Answers

Have a look at this related Stack Overflow question.

The reason why this is a challenge is that the Razor method executes on the web server at render time while the javascript executes on the client browser at runtime.

I would solve this by doing something like

var boxIdValue = 233;
var link = '@Html.ActionLink("Detail", "Show", "Boxes", new{boxId=-1}, null)'
link = link.replace('-1', boxIdValue);
var result = title + '<br />' + link;
like image 67
AlexC Avatar answered Oct 12 '22 00:10

AlexC