手机
当前位置:查字典教程网 >编程开发 >asp.net教程 >Silverlight融合ajax实现前后台数据交互
Silverlight融合ajax实现前后台数据交互
摘要:事出偶然,本来公司强调的是用WCF做项目审批流程,WPF/E增强用户体验;由于个人的无知与偷懒,我产生了天真的想法:用WPF/E来做审批流程...

事出偶然,本来公司强调的是用WCF 做项目审批流程,WPF /E 增强用户体验;由于个人的无知与偷懒,我产生了天真的想法:用WPF/E 来做审批流程,这不是一举两得吗。

下面介绍的就是用Silverlight (微软在07 年9 月将WPF/E 更名为Silverlight )融合ajax 做的审批流程。界面上的审批流程从下向上包括3部分,部门审批,科技处审批,厂长审批。实现的功能是可以定制审批流程,比如审批流程是部门审批--> 厂长审批,也可以定制成科技处审批--> 厂长审批。定制的数据存在后台xml 文件中。

前台Silverlight 表现层语言xaml , 后台服务器脚本语言C# ,数据存储格式xml ,中间数据传输技术ajax 。

.Net中嵌入Silverlight Page 的方法是在aspx 中调用js 函数传递xaml 文件相对于服务器的路径,如下:

复制代码 代码如下:

<div id="SilverlightControlHost" >

<script type="text/javascript"><></script>

</div>

函数调用Silverlight 的createObjectEx 方法指定xaml source 、parentElement 、events 等,相应代码如下:

复制代码 代码如下:

function createSL(xamlpage)

{

Silverlight.createObjectEx({

source: xamlpage,

parentElement: document.getElementById("SilverlightControlHost"),

id: "SilverlightControl",

properties: {

width: "100%",

height: "100%",

version: "1.1",

enableHtmlAccess: "true"

},

events: {

onLoad:OnLoaded

}

});

// Give the keyboard focus to the Silverlight control by default

document.body.onload = function() {

var silverlightControl = document.getElementById('SilverlightControl');

if (silverlightControl)

silverlightControl.focus();

}

}

还要做的工作是在xaml 后台cs 文件中[ Scriptable ] 表现层WPF 类(当初是Cavas),将该类注册为可脚本化对象(RegisterScriptableObject)和可脚本化event ,并且在js 的events 设定表现层中的event ,实现方法如下:

xaml代码:

[Scriptable]

复制代码 代码如下:

public partial class workflow : Canvas

{

public workflow()

{

WebApplication.Current.RegisterScriptableObject("wpfe", this);

}

......

[Scriptable]

public event EventHandler workflowFunc;

}

js代码:

复制代码 代码如下:

function OnLoaded(sender,args)

{

sender.Content.wpfe.workflowFunc = onWorkflow;

}

另外,如果js 调用xaml 中的可脚本化函数的方法是

var control = document.getElementById("SilverlightControl");

var onReturnWfResult = control.Content.wpfe;

将xaml 中数据传输给后台处理就用到ajax 技术了,在本例中是在onWorkflow 事件中定义XMLHttpRequest,然后通过该ajax 对象将数据传递到后台。该例中的后台脚本语言是C# ,数据接收方法是Request.Params 。

【Silverlight融合ajax实现前后台数据交互】相关文章:

asp.net下利用JS实现对后台CS代码的调用方法

ASP.Net 上传图片并生成高清晰缩略图

ashx文件的使用小结

ASP.net(c#)用类的思想实现插入数据到ACCESS例子

用CSS实现图片倾斜 只支持IE

Asp.NET 随机码生成基类(随机字母,随机数字,随机字母+数字)

ASP.NET Web API标准的“管道式”设计

asp.net水晶报表参数字段在代码中赋值的方法

asp.net如何将后台c#数组传给前台js?

ASP.Net下载大文件的实现方法

精品推荐
分类导航