将JavaScript放在部分视图中是否可以

Tom*_*omy 63 javascript asp.net-mvc partial-views razor

我正在使用Web应用程序,其中主页面包含两个部分:始终可见的常量块和由3个部分视图之一组成的信息块.每个部分视图都作为AJAX请求的结果出现,并且只加载一次(在jquery提供切换窗口之后).它运作良好,但我遇到了一个问题.

部分视图的html代码包含在常量块和info-block中使用的js函数.当页面加载时,这些函数可以"看到"彼此并且它可以工作,但是resharper找不到函数声明并警告我这一点.我无法通过将它们转移到外部js文件来解决问题,因为razor语法可以在他们的代码中找到.

我该怎么办?

谢谢.

更新:

最后,我决定解决将js代码与视图分离的问题.所以新的问题是如何将razor语法包含到js文件中或者什么是可接受的替代方案.我发现的流行解决方案是使用全局变量,数据属性和我更喜欢的解决方案 - John Katsiotis的RazorJS库.

http://djsolid.net/blog/razorjs---write-razor-inside-your-javascript-files

我希望它能够稳定运行并使Resharper感到高兴.

干杯!

更新:

3年后,我回忆起这个问题,并决定根据我的经验对其进行更新.事实上,现在我宁愿不建议使用额外的库.特别是如果您不是项目团队中唯一的成员......如果您在所有库中得到保证,它们会受到创建者和社区的支持,并且可以轻松集成到您的IDE中(例如,如果使用特殊语法) .你的团队中的所有人都应该知道它是如何工作的.所以现在我建议做下面的事情:

  1. 将所有JS保存在单独的文件中.尽可能地隔离它.为它提供外部API.
  2. 从您的视图中调用API函数.
  3. 将所有Razor生成的URL,文本消息,常量作为资源参数传递.

例如:

js文件:

$.api.someInitFunction = function(resources){ ... }
Run Code Online (Sandbox Code Playgroud)

视图:

<script>
    $.api.someInitFunction({
        urls: { myAction: '@Url.Action("MyAction", "MyController")' },
        messages: { error: '@errorMessage' },
        consts: { myConst: @myIntConst }
    });
</script>
Run Code Online (Sandbox Code Playgroud)

Wah*_*tar 34

如果Resharper警告你这不是什么大问题^ _ ^

但如果我是你,我根本不会把JavaScript放在局部视图中.

由于部分视图可以多次插入一个页面,因此您将遇到JavaScripts问题.

对于你的情况,如果你不能将JavaScript分成JS文件,那么只需创建另一个PartialView并将这些脚本放入其中,然后在主页面中呈现它.

  • 如果这是一个小应用程序,你不想花更多的时间在上面,所以只要保持你的工作.但是,如果您正在谈论"编程习惯",那么您应该将JavaScript与Views分开. (3认同)

cod*_*eim 7

如果要编写封装了"小部件"的部分视图,只要将它们包含在页面中就可以工作,那么在部分视图中嵌入脚本块是将标记和初始化脚本封装在局部视图中的一种简洁方法.例如,我可能有一个名为"_EventList"的部分视图,我在整个网站中使用它.如果我放在我的母版页上的两个位置它应该工作,我不想在我的母版页中编写逻辑来初始化小部件.

如果您永远不会在页面中多次使用它,那么它很简单.但如果可能的话,请将脚本包装起来,使其不会执行两次.见下文.为了Stack Overflow片段,我通过在代码片段中重复两次局部视图来模拟它,以表示在母版页中包含两次局部视图.

我的母版页可能如下所示:

<div id="left-nav">
   @Html.Partial("_EventList")           
</div>

<div id="body">
</div>

<div id="right-nav">
   @Html.Partial("_EventList")
</div>
Run Code Online (Sandbox Code Playgroud)

例:

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<!-- Self-contained partial view containing widget -->

<div id="widgetDiv" class="panel panel-default">

    <div class="panel-heading">Event Dates</div>
    <div class="panel panel-group">
       <ul class="widget">
         <!-- These will load dynamically -->
       </ul>
    </div>

    <script>
        $(document).ready(function() {

            // Run this once only in case widget is on page more than once
            if(typeof $widget == 'undefined') {
                $widget = $("ul.widget"); // could be more than one
                // mock data to simulate an ajax call
                var data = [
                   {Description: "March", StartDate: "03/01/2015"},
                   {Description: "April", StartDate: "04/01/2015"},
                   {Description: "May", StartDate: "05/01/2015"}
                ];

                $.each($widget, function(w, widget) {
                    // might be an $.ajax call
                    $.each(data, function(i, row) {
                        $(widget).append("<li><a href='/Widget/Search?startDate=" + row.StartDate + "'>" + row.Description + "</a></li>");
                    });
                });
            }
        });
    </script>
</div>
<!-- End of widget / partial view -->



<!-- Second copy of above for sake of example snippet -->
<!-- No need to read further -->









<!-- Self-contained partial view containing widget -->

<div id="widgetDiv" class="panel panel-default">

    <div class="panel-heading">Event Dates</div>
    <div class="panel panel-group">
       <ul class="tinylist nav nav-sidebar widget">
         <!-- These will load dynamically -->
       </ul>
    </div>

    <script>
        $(document).ready(function() {

            // Run this once only in case widget is on page more than once
            if(typeof $widget == 'undefined') {
                $widget = $("ul.widget"); // could be more than one
                // mock data to simulate an ajax call
                var data = [
                   {Description: "March", StartDate: "03/01/2015"},
                   {Description: "April", StartDate: "04/01/2015"},
                   {Description: "May", StartDate: "05/01/2015"}
                ];

                $.each($widget, function(w, widget) {
                    // might be an $.ajax call
                    $.each(data, function(i, row) {
                        $(widget).append("<li><a href='/Widget/Search?startDate=" + row.StartDate + "'>" + row.Description + "</a></li>");
                    });
                });
            }
        });
    </script>
</div>
<!-- End of widget / partial view -->
Run Code Online (Sandbox Code Playgroud)


eag*_*orm 5

我同意 Wahid 的观点,即你不应该将 JavaScript 完全部分地或以其他方式放入视图中。我已经看过足够多的这样做的代码,知道它只会带来任何好处。

我还想说,您应该能够将封装在 Razor 语法中的逻辑传输到 JavaScript 中,您只需要将逻辑所需的信息传递给 JavaScript 即可。

我只是根据下一条评论的经验进行猜测,但您应该像设计 C# 或 VB.NET 代码结构一样设计 JavaScript。这样,您使用 Razor 的逻辑就应该是 JavaScript 的一部分。

这样你的 JavaScript 将更容易维护,我想 Resharper 也应该更高兴。