MVC3剃刀:调用从视图中的javascript函数 [英] MVC3 Razor: call javascript function from view

查看:104
本文介绍了MVC3剃刀:调用从视图中的javascript函数的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我在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'+ stu​​nden; }
        的document.getElementById(id)的.innerHTML ='检查现在IST:'+ stu​​nden +:+ 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>
}


  1. 任何其他更好的方式?

  2. 这是一个好的做法呢?我不知道这是否是正确的投入_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>
}

JS小提琴例

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>
}

  1. Any other "better" way?
  2. 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>
}

JS Fiddle Example

这篇关于MVC3剃刀:调用从视图中的javascript函数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆