Asp.NET误人子弟教程:在MVC里面结合JQ实现AJAX

2024-03-20 01:32

本文主要是介绍Asp.NET误人子弟教程:在MVC里面结合JQ实现AJAX,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

声明:本教程是误人子弟的,如果你想成为高手,那千万不要往下读。
在ASP.NET 的WebForm中,你可能发现实现AJAX很简单,因为.NET类库都为你准备好了UpdatePanel控件,用该控件来实现AJAX就等于一行代码都不用写。
然而,在MVC里面,几乎所有的服务器控件都失效了,那怎么办呢?用传统的JS代码的话又会很复杂,呵呵,放心,别忘了,当下jQuery是很流行的,做WEB开发自然是少不了JQ,虽然严格上说,它是提供给前台的网页设计人员使用的,但对于AJAX,我们不妨也用上它。
 
今天,我们一起来做一个简单的玩意儿,通过JQ来实现在MVC框架下的AJAX功能吧。
1、新建一个ASP.NET MVC应用程序项目,新建项目方法(略)。
2、把模板默认生成的Models、Controllers、Views下面的类和页面全部删除,呵呵,不需要,免得浪费硬盘空间,老师过说,一KB空间一串金,串金难买一KB空间。
3、在Models目录下新建一个Person类,类带三个公共属性:Name,City,QQ。
    public class Person
{
public string Name { get; set; }
public string City { get; set; }
public string QQ { get; set; }
}

4、在Controllers目录上右击,从弹出的菜单中依次选择【添加】→【Controller...】,在弹出对话框中输入控制器的名称。注意,控制器名必须以Controller结属。

把控制器命名为PersonController。

5、在控制器中定义一个模拟搜索的方法。

        // GET: /Person/Search
public JsonResult Search()
{
// 取得URL参数值
string key = Request.QueryString["s"];
List<Person> list = new List<Person>();
list.AddRange(new Person[]
{
new Person{Name="aaaakd",City="天津",QQ="22654554"},
new Person{Name="zooewu",City="长沙",QQ="665542114"},
new Person{Name="ddalion",City="北京",QQ="224545"},
new Person{Name="odtkkfuq",City="上海",QQ="624587"},
new Person{Name="pulirjd",City="北京",QQ="33211576"},
new Person{Name="woegd",City="北京",QQ="32845215"},
new Person{Name="menksale",City="广州",QQ="88017564"},
new Person{Name="fulintang",City="上海",QQ="4675136"},
new Person{Name="gkaong",City="徐州",QQ="354115465"},
new Person{Name="fgdongse",City="南京",QQ="5514364"},
new Person{Name="zhafule",City="北京",QQ="0124560"},
new Person{Name="tueimesh",City="北京",QQ="2138575"},
new Person{Name="huzmte",City="珠海",QQ="72669952"},
new Person{Name="kefbicha",City="长沙",QQ="6845126"},
new Person{Name="niufangz",City="西安",QQ="62154024"},
new Person{Name="goupan",City="东莞",QQ="8546221165"},
new Person{Name="hatengf",City="深圳",QQ="123621"},
new Person{Name="dangwu",City="大同",QQ="6584123355"},
new Person{Name="qiulikljh",City="海口",QQ="32564411"},
new Person{Name="lanjuii",City="山海关",QQ="684895412"}
});
// 通过搜索关键查出合适字录
List<Person> result = list.Where(p => p.Name.Contains(key)).ToList();
// 返回JSON
return Json(result);
}

6、在Global.asax文件中,把映射的URL路改一下,把控制器的名字改为刚才建的控制器名字,但不要Controller,只要前面一部分。

            routes.MapRoute(
"Default", // Route name
"{controller}/{action}/{id}", // URL with parameters
new { controller = "Person", action = "Index", id = UrlParameter.Optional } // Parameter defaults
);

7、在Views目录下新建一个文件夹,注意名字要和控制器一样,命名为Person。

8、在刚才的Person文件夹下面再新建一个页面,名为Index.aspx,注意,要和Action的名字相同。

好,现在尝试运行一下,看是否正常。按下F5调试运行。
OK,看到页面就说明运行成功了。

9、打开刚才建的视图页面,我们来做一个简单的搜索页面,该页面使用AJAX来完成搜索,也就是说搜索结果在页面中动态显示,页面不刷新。

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<script type="text/javascript" src="../../Scripts/jquery-1.4.1.js"></script>
<style type="text/css">
.tb
{
padding: 0px;
border: 1px solid #33CCFF;
border-collapse: collapse;
border-spacing: 0px;
font-size: 13px;
font-family: 黑体;
}
th
{
margin: 0px;
padding: 3px;
background-color: #003399;
border-right-style: solid;
border-bottom-style: solid;
border-right-width: 1px;
border-bottom-width: 1px;
border-right-color: #33CCFF;
border-bottom-color: #33CCFF;
color: #FFFFFF;
text-align: center;
width: 80px;
font-size: 14px;
}
td
{
border-right-style: solid;
border-bottom-style: solid;
border-right-width: 1px;
border-bottom-width: 1px;
border-right-color: #33CCFF;
border-bottom-color: #33CCFF;
padding: 3px;
}
</style>
</head>
<body>
<div>
<h2>
欢迎进入ASP.NET误人子弟示例程序</h2>
</div>
<div>
请输入关键词:
<input type="text" id="txt" name="txt" />
<input type="button" id="btn" name="btn" value="搜索" οnclick="getList()" />
</div>
<div>
<h4>
搜索结果</h4>
<table id="tb" class="tb">
</table>
</div>
</body>
</html>

下面是处理AJAX的脚本。

<script type="text/javascript">
function getList() {
// 取出文本框中的值
var key = $("#txt").val();
$.getJSON('/Person/Search?s=' + key, function(data) {
var html = '<tr><th>姓名</th><th>城市</th><th>QQ号</th></tr>';
$.each(data, function(index, item) {
html += '<tr>' +
'<td>' + item.Name + '</td>' +
'<td>' + item.City + '</td>' +
'<td>' + item.QQ + '</td>' +
'</tr>';
});
$("#tb").html(html);
});
}
</script>

10、再来运行一下,在文本框中输入“z”,点搜索,奇怪了,没反应,咋么回事呢?

首先,你要检查一下你的javascript代码,尤其是jQuery代码,很容易写错,好的,反复检查了,没错啊,是这样,那为什么没反应呢?

 

来,咱们再来打开控制器的C#代码,把Search方法的return后面的代码改一下,也就是在Json方法另一个重载,再加一个允许GET方式访问的参数:

        public JsonResult Search()
{
........
// 返回JSON
return Json(result, JsonRequestBehavior.AllowGet);
}

然后,你再运行一下看,结果出来了没?

这篇关于Asp.NET误人子弟教程:在MVC里面结合JQ实现AJAX的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/827871

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P