在javascript代码中使用Url.Action的更好解决方案

Sim*_*mon 23 javascript asp.net asp.net-mvc

在我当前使用asp.net MVC 3(使用razor)的项目中,当我进行Ajax调用时,我必须将JS保留在视图页面上,因为我想使用Url.Action来生成URL.这意味着我无法将js代码拆分为.JS文件,是否有比我目前正在做的更好的解决方案.

Jam*_*iec 17

我倾向于以与上面类似的方式实现这一点,因为我喜欢命名我的javascript,所以有一点点不同.

javascript文件看起来像:

var my = {};

my.viewname = 
{
   init : function(settings){
      // do some work here. settings.someImportantUrl has my json/ajax url eg.
      alert(settings.someImportantUrl );
   }
}
Run Code Online (Sandbox Code Playgroud)

那么我的观点将包含以下内容:

<script language='javascript'>
  // allocate an object with variables you want to use in the external js file
  var settings = {someImportantUrl: '<%=Url.Action(...)%>'};
  // call an init method for the current view
  my.viewname.init(settings);
</script>
Run Code Online (Sandbox Code Playgroud)

  • @Simon - 名称空间为任何编程带来同样的东西; 组织,清晰度和良好实践. (2认同)

Ego*_*4eg 10

您只能在视图中定义网址,并将所有其他javascript代码保存在.js文件中.

在我的MVC.NET 1应用程序中有来自视图的代码:

<script type="text/javascript" src="<%=Url.Content("~/Scripts/Account/ManageUsers.js")%>"></script>

<script type="text/javascript" src="<%=Url.Content("~/Scripts/Account/ManageUsersAndGroups.js")%>"></script>

<script type="text/javascript">

    var getUsersUrl = '<%= Url.Action("GetUsers", "Account") %>';
    var getUserDetailsURL = '<%= Url.Action("GetUserDetails", "Account") %>';

    <%If Not ViewData("readOnly") Then%>
    var changeRolePermissionsUrl = '<%= Url.Action("ChangeRolePermissions", "Account") %>';
    var deleteUserUrl = '<%= Url.Action("DeleteUser", "Account") %>';
    var resetPasswordUrl = '<%= Url.Action("ResetPassword", "Account") %>';
    var updateUserGroupsUrl = '<%= Url.Action("UpdateUserGroups", "Account") %>';
    var updateUserDetailsUrl = '<%= Url.Action("UpdateUserDetails", "Account") %>';
    <%End If%>  
</script>
Run Code Online (Sandbox Code Playgroud)

因此,您甚至不能为由于安全原因而无法由用户调用的操作呈现URL.(ViewData("readOnly")表示用户只能读取屏幕访问权限).

并且js文件中有一部分代码:

function GetUsersList() {
    ajax.getJSON(getUsersUrl, {}, function(data) {
        if (data != false) {
            ShowUsers(data);
        }
        else {
            jAlert('Error during users list retrieving.');
        }
    });
}
Run Code Online (Sandbox Code Playgroud)

getUsersUrl在视图中定义