`
wangdeshui
  • 浏览: 253421 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论
阅读更多

我们在silverlight1.0 想调用javascript事件,直接在事件后写上函数名就可以,比如Loaded=SayHell, 但是在silverlight1.1 里是不行的,因为Silverlight1.1中一个XAML文件对应一个C#文件,和aspx与aspx.cs的对应关系一样,在XAML中可以定义一个Silverlight对象的事件代理,在对应的.xaml.cs文件中定义事件处理方法,在方法中可以操作XAML对象。但是如何为一个XAML对象定义一个JAVASCRIPT事件及事件处理方法呢?

    在Silverlight1.1工程中一个Silverlight页面通常会有四个文件:html宿主文件及与之关联的html.js文件;XAML文件及与之对应的.xaml.cs文件。其中html宿主文件是一个普通的HTML文件用来作为Silverlight对象的容器,.html.js文件用会根据XAML文件来创建Silverlight对象显示在HTML文件中,XAML文件是一个基于XML格式的文件,用来定义Silverlight对象模型。

那么我们如何调用呢,以下就是示例:

1. 打开vs2008, 新建一个silverlight项目CallJavascript,默认生成如下文件

image

 

2. 在page.xaml的cavas下加入下面的代码

<!----><TextBlock Width="314" Height="72" Canvas.Left="78" Canvas.Top="142" Text="Hello World" 
MouseLeftButtonDown
="mCallJsTextBlockOnClicked" TextWrapping="Wrap"/>

我们为这个对象设置了事件代理MouseLeftButtonDown="mCallJsTextBlockOnClicked"

最后代码会使这个样子

<!----><Canvas x:Name="parentCanvas"
        xmlns
="http://schemas.microsoft.com/client/2007"
        xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml"
        Loaded
="Page_Loaded"
        x:Class
="CallJavascript.Page;assembly=ClientBin/CallJavascript.dll"
        Width
="640"
        Height
="480"
        Background
="White"
        
>
    
<TextBlock Width="314" Height="72" Canvas.Left="78" Canvas.Top="142" Text="Hello World" 
               MouseLeftButtonDown
="mCallJsTextBlockOnClicked" TextWrapping="Wrap"/>
</Canvas>

 

3. 修改page.xaml.cs

<!---->using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Ink;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;
using System.Windows.Browser;
namespace CallJavascript
{
    [Scriptable]
    
public partial class Page : Canvas
    
{
        [Scriptable]
        
public event EventHandler onTextBlockClicked;
        
public void Page_Loaded(object o, EventArgs e)
        

            WebApplication.Current.RegisterScriptableObject(
"calljsObject"this);
            
// Required to initialize variables
            InitializeComponent();
        }
 
        
void mCallJsTextBlockOnClicked(object sender, MouseEventArgs e)
        
{
            
if (this.onTextBlockClicked != null)
            
{
                onTextBlockClicked(sender, e);
            }

        }

    }

}

引用 using System.Windows.Browser;

在C#文件中定义了Silverlight对象点击事件的处理方法,在这个方法里边会调用另一个事件,这个事件对象(onTextBlockClicked)有一个[Scriptable]标记,说明这个事件被定义为一个JS脚本事件,另外还要注意这个事件所在的类也要打上[Scriptable]标记,并且注册了一个脚本对象(在本例中是calljsObject)

4. 修改Testpage.html.js为


<!---->// JScript source code

//contains calls to silverlight.js, example below loads Page.xaml
function createSilverlight()
{
    Silverlight.createObjectEx(
{
        source: 
"Page.xaml",
        parentElement: document.getElementById(
"SilverlightControlHost"),
        id: 
"SilverlightControl",
        properties: 
{
            width: 
"100%",
            height: 
"100%",
            version: 
"1.1",
            enableHtmlAccess: 
"true"
        }
,
        events: 
{
                onLoad:
function(sender,args)
                        
{
                            sender.Content.calljsObject.onTextBlockClicked 
= function (sender, args)
                                                                    
{alert("Hello World, I am Jack_wangds");};
                        }


        }

    }
);
    
// Give the keyboard focus to the Silverlight control by default
    document.body.onload = function() {
      
var silverlightControl = document.getElementById('SilverlightControl');
      
if (silverlightControl)
      silverlightControl.focus();
    }


}

可以看到这是一个标准的createSilverlight方法,但是不同的是我在这个方法的events参数中增加了一个onLoad事件,在这个事件中我对onTextBlockClicked事件进行了初始化,从这一句初始化代码可以看到calljsObject就是刚才我在C#文件中注册的脚本对象。这个事件的处理函数也可以写在一个独立的JS文件中,只要在Silverlight宿主文件中将其引用就可以了。
 

总结,silverlight1.1 其优势就是我们用托管代码如C#来写代码,这就造成了我们直接使用javascript比较繁琐,还好不是很繁琐,如果你不想用这个新特性而喜欢手写javascript,那还是用1.0吧

分享到:
评论

相关推荐

    Silverlight学习和json

    与XML相比,JSON通常被认为更简洁且解析速度更快,因为它是为JavaScript设计的,所以在JavaScript环境中解析和生成JSON数据非常直观。JSON-RPC(Remote Procedure Call)是一种使用JSON进行远程调用的协议,允许...

    庖丁解牛 纵向切入ASP.NET 3.5控件和组件开发 part1

    2.4.1 调试页面中的javascript脚本(方法一) 22 .2.4.2 调试页面中的javascript脚本(方法二) 23 2.4.3 调试非嵌入式javascript脚本文件 23 2.4.4 调试嵌入式javascript脚本资源文件 24 2.4.5 高效率调试的...

    庖丁解牛 纵向切入ASP.NET 3.5控件和组件开发 part2

    2.4.1 调试页面中的javascript脚本(方法一) 22 .2.4.2 调试页面中的javascript脚本(方法二) 23 2.4.3 调试非嵌入式javascript脚本文件 23 2.4.4 调试嵌入式javascript脚本资源文件 24 2.4.5 高效率调试的...

    ASP.NET4高级程序设计第4版 带目录PDF 分卷压缩包 part1

    2.4.3 事件如何与事件处理程序连接 2.5 Web项目 2.5.1 基于项目的开发 2.5.2 创建Web项目 2.5.3 迁移旧版Visual Studio创建的网站 2.6 Visual Studio调试 2.6.1 单步调试 2.6.2 变量监视 2.6.3 ...

    ASP.NET4高级程序设计(第4版) 3/3

    2.4.3 事件如何与事件处理程序连接 46 2.5 Web项目 47 2.5.1 基于项目的开发 47 2.5.2 创建Web项目 48 2.5.3 迁移旧版Visual Studio创建的网站 49 2.6 Visual Studio调试 51 2.6.1 单步调试 52 2.6.2 ...

    工程硕士学位论文 基于Android+HTML5的移动Web项目高效开发探究

    目前市场业务中在产品以及其他项目的认证和检测方面存在诸多不便,用户需要实地考察并频繁与检测单位沟通,填写繁琐的纸质检测报告、当面送递样品,对于检测环节中存在的问题难以及时交互并处理。市场上相应的检测...

    学习ASP.NET(比较细致)

    - **活动**:定义工作流中的任务。 - **状态机**:基于状态转移的工作流。 - **规则引擎**:基于规则的工作流决策。 #### 四、其他关键技术 **4.1 多层架构** - **表现层**:用户界面。 - **业务逻辑层**:处理业务...

    移动端混合开发框架分析.docx编程资料

    - 使用XML或Flex布局构建界面,并通过JavaScript与原生代码交互。 **结构图:** - 由JS执行引擎、UI框架和原生插件组成。 **ReactNative** **简介:** - React Native是Facebook开发的一个框架,允许使用React...

Global site tag (gtag.js) - Google Analytics