MVC3剃刀:调用从视图中的javascript函数 [英] MVC3 Razor: call javascript function from view
问题描述
我在MVC3剃刀新希望显示在一个视图(index.cshtml)运行时间。
我使用JavaScript函数,并把它放在_Layout.cshtml因此所有其他的家的观点可以用它(见下面的代码片段)
<!DOCTYPE HTML>
< HTML和GT;
< HEAD>
<间的charset =UTF-8/>
<标题>
@ ViewBag.Title
< /标题>
<链接HREF =@ Url.Content(〜/内容/的site.css)的rel =stylesheet属性类型=文/ CSS/>
<脚本的src =@ Url.Content(〜/脚本/ jQuery的-1.5.1.min.js)TYPE =文/ JavaScript的>< / SCRIPT>
<脚本的src =@ Url.Content(〜/脚本/ Modernizr的-1.7.min.js)TYPE =文/ JavaScript的>< / SCRIPT>
< /头>
<脚本类型=文/ JavaScript的>
VAR UHR =新的日期();
VAR minuten;
VAR stunden;
VAR sekunden;
VAR间隔= 500; 功能数据(ID){
uhr.setTime(uhr.getTime()+间隔);
window.setTimeout(函数(){数据(ID)},间隔);
minuten = uhr.getMinutes();
stunden = uhr.getHours();
sekunden = uhr.getSeconds();
如果(minuten小于10){minuten ='0'+ minuten; }
如果(sekunden小于10){sekunden ='0'+ sekunden; }
如果(stunden小于10){stunden ='0'+ stunden; }
的document.getElementById(id)的.innerHTML ='检查现在IST:'+ stunden +:+ minuten +:+ sekunden;
}
< / SCRIPT>
我的问题:
1.我怎么能叫从index.cshtml这个功能(例如数据(UHR))?我试(见下)不工作:
@section侧栏{
&所述p为H.;
< UL>
<立GT;< A HREF =Index.cshtml>添加工作与LT; / A>< /李GT&;
<立GT;< A HREF =About.cshtml>关于< / A>< /李>
< / UL>
&所述; / P>
&所述p为H.;
时间是:数据(UHR);
&所述; / P>
}
- 任何其他更好的方式?
- 这是一个好的做法呢?我不知道这是否是正确的投入_Layout.cshtml javascript函数。
Thx提前。
您应该摆脱_Layout.cshtml的code到一个单独的.js文件,并添加对它的引用。
此外,你应该改变index.cshtml code是这样的:
@section侧栏{
&所述p为H.;
< UL>
<立GT;< A HREF =Index.cshtml>添加工作与LT; / A>< /李>
<立GT;< A HREF =About.cshtml>关于< / A>< /李>
< / UL>
&所述; / P>
&所述p为H.;
的时间是:或其可跨度的id =UHR>&下; /跨度>
&所述; / P>
<脚本类型=文/ JavaScript的>数据(UHR);< / SCRIPT>
}
I am new in MVC3 Razor and want to show running time on a view (index.cshtml). I use a javascript function and put it in _Layout.cshtml so all other "home" views can use it (see following snippet)
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>
@ViewBag.Title
</title>
<link href="@Url.Content("~/Content/Site.css")" rel="stylesheet" type="text/css" />
<script src="@Url.Content("~/Scripts/jquery-1.5.1.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/modernizr-1.7.min.js")" type="text/javascript"></script>
</head>
<script type="text/javascript">
var uhr = new Date();
var minuten;
var stunden;
var sekunden;
var interval = 500;
function datum(id) {
uhr.setTime(uhr.getTime() + interval);
window.setTimeout(function () { datum(id) }, interval);
minuten = uhr.getMinutes();
stunden = uhr.getHours();
sekunden = uhr.getSeconds();
if (minuten < 10) { minuten = '0' + minuten; }
if (sekunden < 10) { sekunden = '0' + sekunden; }
if (stunden < 10) { stunden = '0' + stunden; }
document.getElementById(id).innerHTML = 'Jetzt ist: ' + stunden + ':' + minuten + ':' + sekunden;
}
</script>
My questions: 1. how can I call this function (e.g. datum("uhr")) from index.cshtml? My try (see following) doesn't work:
@section SideBar {
<p>
<ul>
<li><a href="Index.cshtml">Add Job</a></li>
<li><a href="About.cshtml">About</a></li>
</ul>
</p>
<p>
The time is: datum("uhr");
</p>
}
- Any other "better" way?
- Is it a good practice? I am not sure if it is correct putting javascript function in _Layout.cshtml.
Thx in advance.
You should move the code from _Layout.cshtml into a seperate .js file and add a reference to it.
Also, you should change the index.cshtml code to be this:
@section SideBar {
<p>
<ul>
<li><a href="Index.cshtml">Add Job</a></li>
<li><a href="About.cshtml">About</a></li>
</ul>
</p>
<p>
The time is: <span id="uhr"></span>
</p>
<script type="text/javascript">datum("uhr");</script>
}
这篇关于MVC3剃刀:调用从视图中的javascript函数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!