题目中提到的控制器指的是.NET  MVC的控制器,不是angularjs的控制器。

首先看主页面的代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<script src="https://cdn.staticfile.org/angular.js/1.7.5/angular.min.js"></script>
<style>
.out {
height: 500px;
} .top {
background-color: lawngreen;
height: %;
} .content {
display: flex;
height: %;
} .left {
background-color: aqua;
width:%;
} .right {
width:%;
background-color: beige;
} .foot {
height: %;
background-color: blueviolet;
}
</style> </head>
<body>
<div class="out" ng-app="App" ng-controller="Parents2Ctl">
<div class="top">{{PublicArea1}}
<div>
<input type="button" value="Get调用后台" ng-click="btn1()" />
<input type="button" value="Get传参调用后台" ng-click="btn2()" />
<input type="button" value="Get传参调用后台,获取对象返回值" ng-click="btn3()" />
<input type="button" value="post调用后台" ng-click="btn4()" />
<input type="button" value="post传参调用后台" ng-click="btn5()" />
<input type="button" value="post传参调用后台,获取对象返回值" ng-click="btn6()" />
</div>
</div> <div class="content">
<div ng-include="'Childrens/LeftChild.html?v=3'" class="left"></div>
<div ng-include="'Childrens/RightChild.html'" class="right"></div>
</div>
<div class="foot">{{PublicArea2}}</div>
</div>
<script src="Parents2.js?v=2"></script>
<script src="Childrens/Left.js?v=2"></script>
<script src="Childrens/Right.js"></script>
</body>
</html>

页面中,还是通过ng-include的方式引入了子页面,同时对各个部分的html,下面引入了对应的js脚本文件。

Parents2.js:

var publicData;
var App = angular.module('App', []);
App.controller('Parents2Ctl', function ($scope, $http) {
$scope.PublicArea1 = "公共区域顶部";
$scope.PublicArea2 = "公共区域底部";
$scope.btn1 = function () {
$http.get("/Home/Test1").then(function (response) {
alert(response.data);
});
}
$scope.btn2 = function () {
$http.get("/Home/Test2?name=Join&address=adaww.efw").then(function (response) {
alert(response.data);
});
}
$scope.btn3 = function () {
$http.get("/Home/Test3?txt=Join").then(function (response) {
alert(response.data.name);
});
}
$scope.btn4 = function () {
$http.post("/Home/Test1").then(function (response) {
alert(response.data);
});
}
$scope.btn5 = function () {
$http.post("/Home/Test2", { name: 'Join', address:'adaww.efw'}).then(function (response) {
alert(response.data);
});
}
$scope.btn6= function () {
$http.post("/Home/Test4", {txt:'Join'}).then(function (response) {
alert(response.data.name);
});
}
});

在主页面的js脚本中定义了一个公共变量publicData,用来在各个js脚本中传值。

这里主要是通过$http的get和post来访问mvc控制器中的函数。在Home控制器中,有以下的函数:

  public string Test1()
{
return "Hello World!";
}
public string Test2(string name,string address)
{
return $"Hello {name}!Your famally in {address}";
}
public JsonResult Test3(string txt)
{
var t= new MT() { name = txt, age = , sex = "男" };
//当用get方式访问返回类型是JsonResult函数的时候,下面的json必须在第二个参数赋值 JsonRequestBehavior.AllowGet
return Json(t, JsonRequestBehavior.AllowGet);
}
public JsonResult Test4(string txt)
{
var t = new MT() { name = txt, age = , sex = "男" };
return Json(t);
}

这样主页面就完成了,运行效果:

LeftChild.html:

<div ng-controller="LeftCtr">
<h2>{{LeftTitle}}</h2>
<input type="button" value="向右侧传值" ng-click="setValue()" />
<div>
<input type="button" value="Get调用后台" ng-click="service_btn1()" />
<input type="button" value="Post调用后台" ng-click="service_btn2()" />
</div>
</div>

Left.js:

App.controller('LeftCtr', function ($scope,  Home) {
$scope.LeftTitle = "左侧菜单";
$scope.setValue = function () {
publicData = '来自左侧的值';
} $scope.service_btn1 = function () {
var t= Home.Get("Test1");
}
$scope.service_btn2 = function () {
var t = Home.Post("Test2", { name: 'Join', address: 'adaww.efw' });
}
}); App.service("Home", function ($http) {
this.Get = function (ActionName) {
//这里走的是异步
$http.get("/Home/" + ActionName).then(function (response) {
alert(response.data);
});
return "OK";
}
});
App.service("Home", function ($http) {
this.Post = function (ActionName,para) {
//这里走的是异步
$http.post("/Home/" + ActionName,para).then(function (response) {
alert(response.data);
});
return "OK";
}
});

在子页面left的js脚本中,通过自定义服务的方式来访问后台,其本质还是$http的get和post。

RightChild.html:

<div ng-controller="RightCtr">
<input type="button" value="显示来自左侧的值" ng-click="getValue()" />
<ul>
<li ng-repeat="x in books">{{x}}</li>
</ul>
<h1>{{formLeftData}}</h1>
</div>

Right.js:

App.controller('RightCtr', function ($scope) {
$scope.books = ['言情小说', '武侠小说', '玄幻小说', '修真小说'];
$scope.getValue = function () {
$scope.formLeftData = publicData;
}
});

完整页面的效果:

AngularJs调用NET MVC 控制器中的函数进行后台操作的更多相关文章

  1. C语言学习_C如何在一个文件里调用另一个源文件中的函数

    问题 C如何在一个文件里调用另一个源文件中的函数,如题. 解决办法 当程序大了代码多了之后,想模块化开发,不同文件中存一点,是很好的解决办法,那我们如何做才能让各个文件中的代码协同工作呢?我们知道,m ...

  2. MVC控制器中动作方法返回的结果

    在MVC控制器中主要的返回方式有如下几种: 1.Content(): 返回文本类型的ContentResult,比如“这是我做的一个MVC”. 2.File(): 返回文件类型的内容FileResul ...

  3. asp.net MVC控制器中返回JSON格式的数据时提示下载

    Asp.net mvc在接收的是JSON格式的数据,但是奇怪的是在IE中提示下载文件,其他浏览器中一切正常,下载后,里面的内容就是在控制器中返回的数据.代码如下: 视图中js代码: $("# ...

  4. ASP.NET在MVC控制器中获取Form表单值的方法

    在网站开发中我们经常需要用到表单,那么,在前台页面的表单中提交到后台控制器后,后台控制器如何接收表单提交过来的数据呢?下面我们介绍几种常用的方法. 我们先看看前台页面,这里我们用一个用户名和密码的表单 ...

  5. 在ASP.NET MVC控制器中获取链接中的路由数据

    在ASP.NET MVC中,在链接中附加路由数据有2种方式.一种是把路由数据放在匿名对象中传递: <a href="@Url.Action("GetRouteData&quo ...

  6. 如何调用.so动态库中的函数,如何把自己的函数导出为.so的动态库函数供别人调用

    调用.so中的函数和平常的函数没有区别,只是在编译连接时加上-lxxxx就行了.要生成.so库,则编译时用下面的语句:gcc -shared -Wl,-soname,libmyfun.so -o li ...

  7. 在IE中MVC控制器中返回JSON格式的数据时提示下载

    最近做项目时,视图中用jquery.form.js异步提交表单时,接收的是JSON格式的数据,但是奇怪的是在IE中提示下载文件,其他浏览器中一切正常,下载后,里面的内容就是在控制器中返回的数据.代码如 ...

  8. C#调用GDI+1.1中的函数实现高斯模糊、USM锐化等经典效果。

    http://www.cnblogs.com/Imageshop/archive/2012/12/13/2815712.html 在GDI+1.1的版本中,MS加入不少新的特性,其中的特效类Effec ...

  9. asp.net mvc 控制器中操作方法重载问题 解决

    Controllers: public ActionResult Index() { return View(db.GuestBooks.ToList()); } // // GET: /Guest2 ...

随机推荐

  1. Github配置SSH

    以前也配置过ssh,但是没有注意用法,在配置一次熟悉流程 检查本机是否有ssh key设置 $ cd ~/.ssh 或cd .ssh 如果没有则提示: No such file or director ...

  2. HNU 12834 Thread Tree

    递归输出即可了 #include<bits/stdc++.h> using namespace std; struct tree{     int dot;     string s; } ...

  3. 运算符与类型转换 mogondb简介

    运算符与类型转换   1.运算符 (1)分类 算术运算符.关系运算符.逻辑运算符.位运算符.赋值运算符.其他运算符 >.算术运算符: 运算符 描述 + 把两个操作数相加 - 从第一个操作数中减去 ...

  4. Chapter1-data access reloaded:Entity Framework(上)

    本章包括以下几个部分: 1.DataSet and classic ADO.NET approach2.Object model approach3.Object/relational mismatc ...

  5. Java 负载均衡

    什么是负载均衡 负载均衡,英文 名称为Load Balance,指由多台服务器以对称的方式组成一个服务器集合,每台服务器都具有等价的地位,都可以单独对外提供服务而无须其他服务器的辅助.通过某种 负载分 ...

  6. Nginx——静态资源服务器(一)

    java web的项目中,我们经常将项目部署到Tomcat或者jetty上,可以通过Tomcat或者jetty启动的服务来访问静态资源.但是随着Nginx的普及,用Nginx来作为静态资源服务器,似乎 ...

  7. C++ pair(对组)用法(转)

    类模板:template <class T1, class T2> struct pair 参数:T1是第一个值的数据类型,T2是第二个值的数据类型. 功能:pair将一对值组合成一个值, ...

  8. python dns server开源列表 TODO

    基于dns lib的,https://github.com/andreif/dnslib 有:https://www.cnblogs.com/anpengapple/p/5664500.html ht ...

  9. repo+manifests+git方式管理安卓代码

    repo+manifests+git方式管理安卓代码 1.repo的获取 repo只是google用Python脚本写的调用git的一个脚本,主要是用来下载.管理Android项目的软件仓库.(也就是 ...

  10. hdu3555(数位DP dfs/递推)

    Bomb Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others)Total Submi ...