Razor/JavaScript and trailing semicolon

2019-01-09 00:10发布

Using Visual Studio 2012, on a Razor view page, in the JavaScript section, I am getting what I think is a battle between Razor syntax vs JavaScript syntax. In particular, the trailing semicolon in the script section is flagged by intellisense and a compiler warning (not error) is delivered:

'Warning 13 Syntax error'.

If I remove it, then I get a statement termination recommendation (ReSharper in this case, but just good practice).

<script type="text/javascript">
    $().ready(function(){
        var customer = @Html.Raw(ViewBag.CustomerJSON);  // <- Razor (I think) doesn't like this semicolon
    });
</script>

Is this a bug in Razor? If so, is there a way I can rewrite this to avoid this issue?

7条回答
来,给爷笑一个
2楼-- · 2019-01-09 00:48

This worked for me

@Html.Raw(string.Format("var customer = {0};", ViewBag.CustomerJSON));
查看更多
虎瘦雄心在
3楼-- · 2019-01-09 00:50
<script type="text/javascript">
    $().ready(function(){
        var customerName = ('@ViewBag.CustomerName');  // <- wrap in parens
    });
</script>

Isn't it as simple as wrapping in parentheses? Putting values through the console seem to work fine with no side effect.

It works for strings, but it still gives the error for non-quoted values, but I still like this for string values. For numbers you could just use parseInt('@Model.TotalResultCount', 10).

查看更多
做自己的国王
4楼-- · 2019-01-09 00:52

Here's a workaround for booleans:

var myBool = @(Model.MyBool ? "true;" : "false;")
查看更多
▲ chillily
5楼-- · 2019-01-09 00:53

This worked for me:

var customer = @Html.Raw(ViewBag.CustomerJSON + ";")
查看更多
爱情/是我丢掉的垃圾
6楼-- · 2019-01-09 00:56

Is this a bug in Razor?

Absolutely not. Run your application, and it will work as expected.

It is a bug in the tools you are using (Visual Studio 2012, ReSharper, ...) that are incapable of recognizing perfectly valid syntax and warning you about something that you shouldn't be warned about. You could try opening an issue on the Microsoft Connect site and signalling this bug if that hasn't already been done.

查看更多
再贱就再见
7楼-- · 2019-01-09 00:56

Since this still seems to be happening and it is a nuisance I figured I will at least let others know what I ended up using as a "hack". I don't want to ignore the warning and would rather accept a hokier syntax (and yes someone is going to say this will kill performance :))

What I use as a workaround is to use a client side addition at the end. For me this error occurred on defining an "integer" constant, so

window.foo = @(Model.Something);

gave me the good old semicolon error. I simply changed this to:

window.foo = @Model.Something + 0;

(In the stated questions case you should just be able to add '', so + ''.

I know there is a whole another addition happening on the client and it isn't elegant, but it does avoid the error. So use it or don't, but I prefer this over seeing the warning/error.

If someone knows of a server-side syntactical workaround for this I would prefer this to the client-side one, so please add.

查看更多
登录 后发表回答