664

I am creating a sample ASP.NET MVC 3 site using Razor as view engine. The razor syntax starts with @ character e.g. @RenderBody(). If I write @test on my cshtml page it gives me parse error

CS0103: The name 'test' does not exist in the current context

How do I escape '@' character?

Michelle Turner
  • 314
  • 5
  • 22
ajay_whiz
  • 17,573
  • 4
  • 36
  • 44
  • 1
    In C#, you can mark keywords with an @ to treat them as variable names rather than keywords. With all I know, it seems impossible to use reserved keywords in Razor this way. – Grimace of Despair Jul 15 '13 at 11:48
  • 1
    @GrimaceofDespair the way to still mark keywords as variables is to enclose the second `@` in braces. I managed to get this working by writing it this way: `@(@new)` – strizzwald Oct 17 '18 at 22:25

16 Answers16

1090

@@ should do it.

Tobiasopdenbrouw
  • 13,811
  • 1
  • 22
  • 27
188

Razor @ escape char to symbols...

<img src="..." alt="Find me on twitter as @("@username")" />

or

<img src="..." alt="Find me on twitter as @("@")username" />
Emre Karahan
  • 1,979
  • 1
  • 12
  • 10
  • 3
    This method seems the best as it will also work for @media css stuff, whereas the HTML entity way probably will not. – ChrisF Jan 30 '14 at 20:40
48

@Html.Raw("@") seems to me to be even more reliable than @@, since not in all cases @@ will escape.

Therefore:

<meta name="twitter:site" content="@twitterSite">

would be:

<meta name="twitter:site" content="@Html.Raw("@")twitterSite">
  • And how do i use this on a huge text with several paragraphs? I have tried with ` instead of " but the result is questionable. No errors on blank rows but error on ` character. – EPurpl3 Dec 23 '19 at 10:05
42

use <text></text> or the easier way @:

Kasper Skov
  • 1,954
  • 10
  • 32
  • 53
  • It's odd the (at sign colon) @: character sequence syntax doesn't work for me, as I try to upgrade my ASP.NET MVC 3 project to MVC4. The exception I get is: "":" is not valid at the start of a code block. Only identifiers, keywords, comments, "(" and "{" are valid." – Michael R Jul 22 '14 at 22:50
  • @Michael That's weird. They must have removed it in version 4. – Kasper Skov Jul 23 '14 at 10:48
  • Hi Kasper Skov, I found the @: issue was not actually related to @: at all. It was related to unnecessarily using @Model, in a @if() {} block. The fix was to drop the at sign on Model. I need to avoid using @ when already in server scope. http://stackoverflow.com/questions/12809855/issue-migrating-mvc3-application-to-mvc4-compiler-error-message-cs1513-expe – Michael R Jul 23 '14 at 17:30
29

Instead of HTML entity I prefer the use of @Html.Raw("@").

Mamun
  • 66,969
  • 9
  • 47
  • 59
CLRBTH
  • 512
  • 4
  • 9
13

@@ is the escape character for @ in Razor views as stated above.

Razor does however try to work out when an '@' is just an '@' and where it marks C# (or VB.Net) code. One of the main uses for this is to identify email addresses within a Razor view - it should not be necessary to escape the @ character in an email address.

Alfamale
  • 1,069
  • 1
  • 9
  • 13
9

For the question about @RazorCodePart1 @@ @RazorCodePart2, you need to the sequence:

@RazorCodePart1 @:@@ @RazorCodePart2

I know, it looks a bit odd, but it works and will get you the literal character '@' between the code blocks.

DragonDTG
  • 583
  • 3
  • 6
8

I just had the same problem. I declared a variable putting my text with the @.

@{
   var twitterSite = "@MyTwitterSite";
}

...

<meta name="twitter:site" content="@twitterSite">
watfy
  • 124
  • 1
  • 2
8

I know this question is old, but I tried all of the above and it didn't help me escape the character "@" in ASP.NET framework (MVC 5) inside a URL. Based on Terje Solem's answer though, the UTF-8 code %40 worked for me. this is the original URL I was trying to reach:

https://unpkg.com/@google/markerclustererplus@4.0.1/dist/markerclustererplus.min.js

this is what worked for me in my code:

https://unpkg.com/%40google/markerclustererplus@4.0.1/dist/markerclustererplus.min.js
Hector Soto
  • 83
  • 2
  • 5
5

this work for me

<meta name="author" content="Alan van Buuren @("@Alan_van_Buuren")">

Or yoy can use: @@Alan_van_Buuren

:D

Alan
  • 101
  • 1
  • 6
2

You can use @@ for this purpose. Like var email = firstName + '\@@' + domain;

Abdus Salam Azad
  • 5,087
  • 46
  • 35
1

I tried all the options above and none worked. This is what I did that worked :

@{
    string str = @"[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,3}$";
}

<td>Email</td>
<td>
   <input type="text" id="txtEmail" required name="email" pattern=@str /> 
</td>

I created a string varible and passed all the RegEx pattern code into it, then used the variable in the html, and Razor was cool with it.

Sender
  • 6,660
  • 12
  • 47
  • 66
1

just add a variable in CSHTML file var myVariable = @"@";

and add it to your layout <span class="my-class"><a href="@myVariale" target="_blank" >link text</a></span>

Speedyjet
  • 51
  • 4
1

I couldn't get any of these to work inside my placeholder attribute, so I used xml special character.

<input type="text" placeholder="fex: firstname&#64;lastname.com"/>

See more examples here. https://www.dvteclipse.com/documentation/svlinter/How_to_use_special_characters_in_XML.3F.html

Terje Solem
  • 816
  • 1
  • 10
  • 25
0

Actually @ should be used with the Razor syntax Keywords or to the variable/model to bind a Value.

For Eg: if test is assigned with value i.e @ { var test = "ABC" } then you can get the value by settings as @test anywhere is cshtml page in html part. otherwise, simple use as @Html.DisplayName("test")

Pavithra
  • 21
  • 7
0

I think in Razor view @Html.Raw() is the best solution for all version and always works for me. I have added an working example cdn URL to provide clear idea.

 @Html.Raw("<script src=\"https://cdn.jsdelivr.net/npm/@popperjs/core@2.11.6/dist/umd/popper.min.js\"></script>")
Liakat Hossain
  • 1,288
  • 1
  • 13
  • 24