использование viewbag с jquery - asp.net mvc 3
У меня есть ViewBag.IsLocal установлен в true в контроллере. Я хотел бы использовать jquery для проверки значения ViewBag и отображения предупреждения.
код:
if(@ViewBag.IsLocal == true)
{
alert("yeah");
}
Я никогда не получить предупреждение. Когда я использую Firebug, чтобы увидеть значение ViewBag, это правда (с капиталом T). Должен ли я сделать что-то вроде == 'True'? Я перепробовал все, но ничего не вышло.
Спасибо за помощь.
H
3 ответов
если вы просматриваете источник на отображаемой странице, что вставляется вместо вашего самородка бритвы? Если IsLocal
является типом bool, я думаю, вы увидите это:
@if(True == true)
{
alert("yeah");
}
причина в том, что true.ToString()
is True
.
в этом случае вам нужно будет сделать сравнение строк там:
if('@ViewBag.IsLocal' == 'True')
{
alert("yeah");
}
предполагая, что вы установили свойство IsLocal в логическое значение в действии контроллера:
public ActionResult Index()
{
ViewBag.IsLocal = true;
return View();
}
вы можете сделать это на вид:
<script type="text/javascript">
@if(ViewBag.IsLocal)
{
<text>alert("yeah");</text>
}
</script>
и, пожалуйста, не используйте ViewBag/ViewData. Используйте модели представлений и строго типизированные представления.
Итак, вот лучший подход, который я предпочитаю. Вы можете сериализовать модель представления в переменную javascript, а затем разобраться с ней. Вот так:
@model MyViewModel
<script type="text/javascript">
var model = @Html.Raw(Json.Encode(Model));
// at this stage model is a javascript variable containing
// your server side view model so you could manipulate it as you wish
if(model.IsLocal)
{
alert("hello " + model.FirstName);
}
</script>
очевидно, что если вам не нужен весь ваш вид модель вы можете сериализовать только подмножество it => только часть, которая будет нужна клиентским скриптам.
Вы можете использовать следующие функции
function parseBoolean(str)
{
return /^true$/i.test(str);
}
и используйте его как
if(parseBoolean('@ViewBag.IsLocal') == true)
{
alert("yeah");
}