zoukankan      html  css  js  c++  java
  • Silverlight与JS交互转载

    http://fdream.net/blog/article/481.aspx

    第一篇:Silverlight中C#获取与修改HTML DOM元素信息
    Silverlight中C#获取与修改HTML DOM元素信息
    ——Silverlight与JavaScript交互第一篇
    ==================================

    在Silverlight 1.1中主要使用C#或者VB进行开发,用C#来处理Silverlight中的所有事物逻辑,而不再是1.0中的JavaScript。也因而使得Silverlight和JavaScript的交互则开始变得复杂起来,无论是要用JavaScript调用C#中的方法,还是要用C#调用JavaScript中的方法。

    用C#和JavaScript交互首先要解决C#读取HTML DOM元素的问题。

    在Silverlight中,要用C#来读取HTML DOM中的元素非常简单,在System.Windows.Browser命名空间下,有一个HtmlDocument、HtmlPage、HtmlElement等类,可以用来读取HTML DOM元素。其读取方法和JavaScript如出一辙。


    引用内容:
    //初始化一个document
    HtmlDocument document = HtmlPage.Document;
    //获取一个DOM节点
    dom = document.GetElementByID("yourDomId");
    //string


    获取到HTML DOM元素结点之后,我们就可以获取DOM元素的值了,例如innerHTML或者innerText或者Value等值了。例如:


    引用内容:
    string s = dom.GetAttribute("value");


    另外,我们也可以通过C#提供的一些方法来动态改变HTML DOM元素的样式或者值。例如:


    引用内容:
    dom.SetAttribute("innerText", "This is Text");
    dom.SetStyleAttribute("left", 40 + "px");
    dom.SetStyleAttribute("top", 35 + "px");


    OK!第一篇就到这里,后面还有两篇,一篇讲怎么通过JavaScript调用Silverlight(C#)里的方法,一篇讲怎么通过Silverlight(C#)来调用JavaScript里的方法

    第二篇:用JavaScript调用Silverlight(C#)中的方法

    用JavaScript调用Silverlight(C#)中的方法
    ——Silverlight与JavaScript交互第二篇
    ======================================

    Silverlight是基于浏览器的应用,因此在Silverlight与用户的交互过程中,经常需要涉及Silverlight与JavaScript的交互,用JavaScript调用Silverlight中的方法也就比较正常。在Silverlight中,提供了这样的解决方式:使用[Scriptable]标签则可以允许JavaScript访问该标签下的类、属性和方法。

    用调JavaScript用Silverlight(C#)中的方法的实现步骤如下:

    在Page类(自动生成的部分)的上面加上[Scriptable]标签,表示允许JavaScript访问这个类。代码如下:


    引用内容:
    [Scriptable]
    public partial class Page : Canvas

     

    其次,我们要为这个Page类实例注册一个名字,可以为该Page类写一个构造函数,然后在构造函数中为其注册。代码如下:


    引用内容:
    [Scriptable]
    public partial class Page : Canvas
    {
        public Page()
        {
            //注册的名字叫做testcallcs
            //在JavaScript代码里面我们会用到这个名字
            WebApplication.Current.RegisterScriptableObject("testcallcs", this);
        }
    }

     

    然后我们再在该类中写一个方法,以供JavaScript调用。这个方法也要用[Scriptable]标签标记,如下:


    引用内容:
    [Scriptable]
    public string TestJS()
    {
        return "This is From C#";
    }

     

    特别需要注意的是:目前Silverlight和JavaScript之间只能传递字符串。因此在处理的过程中要注意类型转换。

    我们再看看,在JavaScript中怎么调用这个方法。


    引用内容:
    <script language="javascript" type="text/javascript">
    //首先找到你的HTML页面中的Silverlight控件
    var ctrl=document.getElementById("SilverlightControl");

    //再找到你刚才注册的Page类实例
    var manage = ctrl.Content.testcallcs;

    //OK,你可以调用刚才写的方法了
    alert(manage.TestJS());
    </script>

    第三篇:用Silverlight(C#)调用JavaScript中的方法

    用Silverlight(C#)调用JavaScript中的方法
    ——Silverlight与JavaScript交互第三篇
    ==================================

    前面一篇讲了用JavaScript调用Silverlight(C#)方法的方式,这一篇讲讲怎样用Silverlight来调用JavaScript方法。

    [Scriptable]标记真是非常的好,可以允许JavaScript访问Silverlight中的方法,还可以允许Silverlight来调用JavaScript方法。

    和JavaScript调用C#方法一样,首先要为Page类注册一个实例名称,如下:


    引用内容:
    [Scriptable]
    public partial class Page : Canvas
    {
        public Page()
        {
            WebApplication.Current.RegisterScriptableObject("OoboyNet", this);
        }
        ....
    }

     

    假设我们在XAML中有这样一个矩形或者文本框或者按钮等等(看你自己的选择咯!),并假设它的x:Name为btnRect,那么我们首先在Page_Loaded方法中为其注册一个事件:

    引用内容:
    btnRect.MouseLeftButtonDown += new MouseEventHandler(btnRect_MouseLeftButtonDown);


    然后我们再在C#中声明一个EventHandler,也用[Scriptable]标记一下,如下:

    引用内容:
    [Scriptable]
    public event EventHandler CallJS;


    我们再来写刚才为按钮btnRect注册的事件控制函数,代码如下:

    引用内容:
    void btnRect_MouseLeftButtonDown(object sender, MouseEventArgs e)
    {
        if (CallJS != null)
        {
            CallJS(this, EventArgs.Empty);
        }
    }


    好C#中的工作做完了,下面就要写JavaScript了。在JavaScript中,首先要在createSivlerlight方法的events中注册一个onLoad事件,代码如下:

    引用内容:
    events: {
        onLoad : OnLoaded
    }


    我们再为这个事件写一个控制函数,代码如下:

    引用内容:
    function OnLoaded(sender, args){
        //我们刚才在C#里注册的实例OoboyNet
        //C#里注册的事件CallJS,现在把这个事件的控制函数指定为JS方法
        sender.Content.OoboyNet.CallJS = JSFunction;
    }


    好吧,剩下的就是最后指定的那个JS方法了:

    引用内容:
    function JSFunction(sender, args){
        alert("This is from JavaScript");
    }


    OK,Silverlight与JavaScript、HTML DOM的交互三篇到这里就结束了。

  • 相关阅读:
    我的第一个项目--总结
    c++中的继承
    指针带来的意想不到的功能紊乱
    一个很难发现的内存泄漏
    我的第一个项目--迭代开发总结
    内存访问冲突问题(非法内存访问)
    Debug Assertion Failed mfc140ud.dll
    javaweb 开发总结五-----servlet开发(一)
    javaweb学习总结四---http协议
    Tomcat服务器学习和使用二·
  • 原文地址:https://www.cnblogs.com/hl3292/p/1945599.html
Copyright © 2011-2022 走看看