ExtJs学习笔记(20)-利用ExtJs的Ajax与服务端WCF交互
ExtJs是一套非常不错的javascript UI库(第一次接触ExtJs的,可到官方网站http://www.extjs.com/deploy/dev/examples/samples.html看下示例。相信不少人会心动的),不仅组件丰富,效果漂亮,而且ExtJs集成的Ajax功能可以方便的与.Net的WCF进行交互.
这里我们将演示ExtJs的FormPanel从WCF加载数据,以及如何提交数据到WCF服务端 1.首先来定义一个用于传输信息的Class(实际开发中,可以是Linq to Sql的Class或任何可序列化的实体类)
[DataContract]
public class MyData
{
[DataMember]
public string id;
[DataMember]
public string text;
}
非常简单,MyData中仅定义了二个成员id,text,加上[DataContract]与[DataMember]表明该类可以序列化
2.再定义几个用于跟ExtJs交互的方法(初次接触Ajax与WCF交互的同志,建议参考一下老张的"Ajax与WCF交互-WCF之美(http://www.cnblogs.com/jillzhang/archive/2008/06/13/1219201.html)")
[ServiceContract(Namespace = "")]
[AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
public class MyService
{
[OperationContract]
[WebInvoke(ResponseFormat = WebMessageFormat.Json, Method = "*", UriTemplate = "GetMyData")]
public MyData GetMyData()
{
System.Threading.Thread.Sleep(1000);
MyData _Node = new MyData() { id = "1", text = "test text" };
return _Node;
}
/**//// <summary>
/// RESTFul WCF用于Get方式取得ExtJs提交的数据(Json)
/// </summary>
/// <param name="id"></param>
/// <param name="text"></param>
/// <returns></returns>
[OperationContract]
[WebInvoke(Method = "*", ResponseFormat = WebMessageFormat.Json, UriTemplate = "SaveMyData?id={id}&text={text}")]
public MyData SaveMyData(string id,string text)
{
System.Threading.Thread.Sleep(1000);
MyData _Node = new MyData() { id = id, text = text };
return _Node;
}
/**//// <summary>
/// Post方法处理ExtJs提交的数据(Json格式)
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[OperationContract]
[WebInvoke(Method = "*", ResponseFormat = WebMessageFormat.Json, UriTemplate = "SaveMyData2")]
public MyData SaveMyData2(Stream input)
{
string s = "";
using (StreamReader sr = new StreamReader(input))
{
s = sr.ReadToEnd();
}
NameValueCollection qs = HttpUtility.ParseQueryString(s);
string id = qs["id"];
string text = qs["text"];
System.Threading.Thread.Sleep(1000);
MyData _Node = new MyData() { id = id, text = text };
return _Node;
}
}
这里定义了三个方法,GetMyData用来让ExtJs获取WCF端的数据,SaveMyData,SaveMyData2用来保存ExtJs提交过来的数据,区别是SaveMyData用于Get方法,SaveMyData2用于Post方法
需要说明的是[WebInvoke(Method = "*", ResponseFormat = WebMessageFormat.Json, UriTemplate = "SaveMyData?id={id}&text={text}")]这一行,这里标明该方法可用Get/Post来处理数据,输出格式是Json字符串,UriTemplate表示该方法支持RESTFul风格,可用/MyService.svc?id=xxx&text=xxx来访问(关于RESTFul WCF,可参见雨痕的文章http://www.rainsts.net/article.asp?id=651 [RESTful WCF]) 3.ExtJs前端页面
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="FormTest.aspx.cs" Inherits="Ajax_WCF.FormTest" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
<title></title>
<link rel="stylesheet" type="text/css" href="js/ext2.2/resources/css/ext-all.css" />
<script type="text/javascript" src="js/ext2.2/adapter/ext/ext-base.js"></script>
<script type="text/javascript" src="js/ext2.2/ext-all.js"></script>
<style>
*{font-size:9pt;line-height:120%;}
</style>
</head>
<body>
<script type="text/javascript">
Ext.onReady(function() {
var form = new Ext.FormPanel({
title: "loadData from Server",
autoHeight: true,
labelAlign: "top",
width: 400,
frame: true,
renderTo: Ext.getBody(),
defaults: { labelWidth: 80, anchor: "95%" },
items: [{
xtype: "textfield",
fieldLabel: "id",
name: "id",
anchor: "90%"
}, {
xtype: "textfield",
fieldLabel: "text",
name: "text",
anchor: "90%"
}],
buttons: [{ text: "加载数据", handler: function() {
//form的load方法总是不成功,无奈只能用Ext.Ajax对象来处理
var loading = Ext.get("loading");
loading.dom.innerHTML = "正在加载。。。";
Ext.Ajax.request({
url: "MyService.svc/GetMyData", //服务器端地址
success: function(request) {
var data = Ext.util.JSON.decode(request.responseText); //将服务端wcf的返回值,格式化为Json对象
form.getForm().setValues(data); //更新form
loading.dom.innerHTML = "";
},
failure: function() {
alert("failure!");
}
});
}
}, {
text: "保存(Get方法)", handler: function() {
var loading = Ext.get("loading");
loading.dom.innerHTML = "正在保存。。。";
Ext.Ajax.request({
url: "MyService.svc/SaveMyData",
method: "GET",
params: { id: "001", text: "Get方法提交的数据" }, //这里为了演示用,随便给出几个值,实际开发时,可将测试值改为用Ext.get("id").dom.value之类
,如果提交成功,将从服务器返回处理结果
success: function(request) {
var data = request.responseText;
loading.dom.innerHTML = "";
alert(data);
},
failure: function() {
alert("failure!");
}
});
}
}, {
text: "保存(Post方法)", handler: function() {
var loading = Ext.get("loading");
loading.dom.innerHTML = "正在保存。。。";
Ext.Ajax.request({
url: "MyService.svc/SaveMyData2",
method: "POST",//注意这里
params: { id: "002", text: "Post方法提交的数据" },
success: function(request) {
var data = request.responseText;
loading.dom.innerHTML = "";
alert(data);
},
failure: function() {
alert("failure!");
}
});
}
}]
});
});
</script>
<div id="loading" style="color:red"> </div>
</body>
</html>
这里利用ExtJs的Ajax对象完成与WCF的交互(初次接触ExtJs Ajax的,可参见ExtJs学习笔记(5)_Ajax示例https://cloud.tencent.com/developer/article/1026518),相当简单!
最近学习了ExtJs和WCF后,个人强力推荐.net3.x时代web开发的绝佳组合: ExtJs(前端) + WCF(web服务层) + Linq To Sql(DAL,以后可能会换成Ado.Net Entity FrameWork),用起来简直是一种享受,目前用ExtJs的人似乎还不多,这里推荐一些学习的资源:http://www.cnblogs.com/yjmyzz/archive/2008/08/31/1280510.html
测试效果图: 1.加载数据
2.Get方法提交数据
3.Post方法提交数据
- 如何修改CDH集群的IP地址
- 如何在Kerberos环境的CDH集群部署Livy
- 如何在Kerberos环境下使用Haproxy实现HiveServer2负载均衡
- Hive与Impala的关键字
- 如何通过Livy的RESTful API接口向非Kerberos环境的CDH集群提交作业
- 如何编译Livy并在非Kerberos环境的CDH集群中安装
- Livy,基于Apache Spark的开源REST服务,加入Cloudera Labs
- 如何在RedHat7上使用Bind搭建DNS服务
- 如何在Redhat7.3的CDH5.14中启用Kerberos
- 如何使用SAML配置Cloudera Manager的身份验证
- 如何使用Shibboleth搭建IDP服务并集成OpenLDAP
- 如何获取Hive正在执行或者已结束的的MapReduce作业的SQL语句
- 如何启用Oozie的HA
- 如何使用Oozie API接口向Kerberos环境的CDH集群提交Spark作业
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- laravel5.1框架基础之路由详解
- flutter 自定义card阴影效果及card使用
- laravel5.1框架基础之Blade模板继承简单使用方法分析
- Yii框架的布局文件实例分析
- React Native 实现热更新并自动签名打包功能
- PHP命名空间用法实例分析
- Android自定义控件实现方向盘效果
- Android 使用fast-verification实现验证码填写功能的实例代码
- android studio 3.6.0 绑定视图新特性的方法
- Android ListView UI组件使用说明
- 解决laravel 出现ajax请求419(unknown status)的问题
- php求斐波那契数的两种实现方式【递归与递推】
- Android 自定义日期段选择控件功能(开始时间-结束时间)
- Yii框架日志操作图文与实例详解
- Flutter 实现虎牙/斗鱼 弹幕功能