发布于 2016-05-31 00:25:51 | 142 次阅读 | 评论: 0 | 来源: 网友投递

这里有新鲜出炉的精品教程,程序狗速度看过来!

Microsoft Silverlight

Microsoft Silverlight是一个跨浏览器的、跨平台的插件,为网络带来下一代基于.NET Framework的媒体体验和丰富的交互式应用程序。Silverlight提供灵活的编程模型,并可以很方便地集成到现有的网络应用程序中。Silverlight可以对运行在Mac或Windows上的主流浏览器提供高质量视频信息的快速、低成本的传递。


两年前Silverlight 还未起名,故事发生在WPF/E 的年代里。07年8月在中软实习时,我承担起了在. Net 中嵌入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 style="width: 662px;height: 622px" id="SilverlightControlHost" > 
<script type="text/javascript"><!-- 
createsL( 'workflow.xaml' ); 
// --></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 。

最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务