Silverlight-브라우저 통합

이 장에서는 브라우저 통합 지원을 사용하여 Silverlight 응용 프로그램이 웹 페이지와 함께 작동하는 방법을 살펴 봅니다.

다음 두 가지 방법으로 브라우저와 Silverlight의 통합을 탐색 할 수 있습니다.

  • 브라우저에서 실행되는 JavaScript 코드는 Silverlight 응용 프로그램 내의 기능에 액세스 할 수 있습니다.

  • Silverlight에는 개체에 대한 JavaScript 래퍼를 제공하는 기능이 있습니다. 너의.NET Silverlight 플러그인 내에서 실행되는 코드는 Silverlight로 인해 HTML DOM 및 기타 브라우저 스크립팅 기능에 액세스 할 수 있습니다. .NET 자바 스크립트 객체에 대한 래퍼.

브라우저 기반 소프트웨어 애플리케이션이 클라이언트에 정보를 지속적으로 저장하는 방법을 살펴 보겠습니다.

Silverlight 및 HTML

HTML의 세계에 관한 한 Silverlight 콘텐츠는 단일 요소에 불과합니다. 이것은 레이아웃에 해당됩니다. Silverlight 플러그인 전체와 모든 콘텐츠는 하나의 개체 요소처럼 보입니다.

다음 사항을 명심해야합니다.

  • Silverlight는 HTML을 대체하는 것이 아니라이를 보완하도록 설계되었습니다. 따라서 DOM의 다른 요소에만 액세스 할 수있는 기능이 중요합니다.

  • 해당하는 경우 Silverlight를 사용할 수 있습니다.

  • 주로 HTML을 사용하는 페이지에서 Silverlight와 브라우저 세계의 통합은 일반적인 HTML 레이아웃에 따라 단순히 DOM 요소로 존재하는 것을 뛰어 넘습니다.

DOM 액세스

Silverlight 콘텐츠는 웹 페이지에 완전히 참여할 수 있어야합니다. 따라서 HTML DOM에 액세스 할 수 있어야합니다. Silverlight는 브라우저 스크립트 개체를 Dot Net 개체로 래핑하는 브리지 개체를 제공합니다.Script object시스템의 클래스. 브라우저 네임 스페이스는 속성을 읽고 쓸 수있는 메서드를 제공하고 브라우저 스크립트 개체에 대한 기능을 제공합니다.

처음에 Script 객체를 확보하는 방법이 필요합니다. Silverlight는 Script 개체와 같은 다양한 기능 페이지에 액세스 할 수있는 HTML 페이지 클래스를 제공합니다.

몇 가지 속성을 가진 객체를 생성하는 간단한 스크립트가있는 간단한 예제를 살펴 보겠습니다. 그들 중 일부는 단순한 값이고 일부는 함수입니다.

<script type = "text/javascript">  
   myJsObject = { 
      answer: 42, 
      message: "Hello, world", 
      modifyHeading: function(title) 
         { document.getElementById('heading').innerHTML = title; }, 
      performReallyComplexCalculation: function(x, y) { return x + y; } 
   }; 
     
</script>

다음은 버튼이 추가되는 XAML 코드입니다.

<UserControl x:Class = "DomAccess.Page" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"  
   Width = "400" Height = "300"> 
   
   <Grid x:Name = "LayoutRoot" Background = "White"> 
      <Button x:Name = "useDomButton" Content = "Use DOM" Width = "75" Height = "30" 
         Click = "useDomButton_Click" /> 
   </Grid>
	
</UserControl>

다음은 HTML 파일에 생성 된 스크립트가 호출되는 버튼 클릭 구현입니다.

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Net; 

using System.Windows; 
using System.Windows.Controls; 
using System.Windows.Documents; 
using System.Windows.Input; 
using System.Windows.Media; 
using System.Windows.Media.Animation; 
using System.Windows.Shapes;
using System.Windows.Browser; 

using System.Diagnostics; 
 
namespace DomAccess { 

   public partial class Page : UserControl { 
	
      public Page() { 
         InitializeComponent(); 
      } 
   
      private void useDomButton_Click(object sender, RoutedEventArgs e) { 
         ScriptObject myJsObject = HtmlPage.Window.GetProperty("myJsObject") as ScriptObject;  
         string[] propertyNames = { "answer", "message", "modifyHeading", 
            "performReallyComplexCalculation" }; 
				
         foreach (string propertyName in propertyNames) { 
            object value = myJsObject.GetProperty(propertyName); 
            Debug.WriteLine("{0}: {1} ({2})", propertyName, value, value.GetType()); 
         }
			
         object result = myJsObject.Invoke("performReallyComplexCalculation", 11, 31);  
         HtmlElement h1 = HtmlPage.Document.GetElementById("heading"); 
         h1.SetProperty("innerHTML", "Text from C# (without JavaScript's help)"); 
         h1.SetStyleAttribute("height", "200px"); 
      } 
   } 
}

아래에 완전한 HTML 파일이 있습니다.

<!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" > 
   <!-- saved from url = (0014)about:internet --> 
	
   <head> 
      <title>DomAccess</title>  
		
      <script type = "text/javascript">  
		
         myJsObject = { 
            answer: 42, 
            message: "Hello, world", 
            modifyHeading: function(title) { 
               document.getElementById('heading').innerHTML = title; }, 
            performReallyComplexCalculation: function(x, y) { return x + y; } 
         }; 
     
      </script> 
     
      <style type = "text/css"> 
		
         html, body { 
            height: 100%; 
            overflow: auto; 
         } 
			
         body { 
            padding: 0; 
            margin: 0; 
         } 
			
         #silverlightControlHost { 
            height: 100%; 
         }
			
      </style>
		
      <script type = "text/javascript" src = "Silverlight.js"></script> 
		
      <script type = "text/javascript"> 
		
         function onSilverlightError(sender, args) { 
            var appSource = ""; 
				
            if (sender != null && sender != 0) { 
               appSource = sender.getHost().Source; 
            }  
				
            var errorType = args.ErrorType; 
            var iErrorCode = args.ErrorCode; 
             
            var errMsg = "Unhandled Error in Silverlight 2 Application " +  
               appSource + "\n" ; 
					
            errMsg += "Code: "+ iErrorCode + "    \n"; 
            errMsg += "Category: " + errorType + "       \n"; 
            errMsg += "Message: " + args.ErrorMessage + "     \n";
				
            if (errorType == "ParserError") { 
               errMsg += "File: " + args.xamlFile + "     \n"; 
               errMsg += "Line: " + args.lineNumber + "     \n"; 
               errMsg += "Position: " + args.charPosition + "     \n"; 
            } else if (errorType == "RuntimeError") {  
				
               if (args.lineNumber != 0) { 
                  errMsg += "Line: " + args.lineNumber + "     \n"; 
                  errMsg += "Position: " +  args.charPosition + "     \n"; 
               } 
					
               errMsg += "MethodName: " + args.methodName + "     \n"; 
            }
				
            throw new Error(errMsg); 
         }
		  
      </script> 
		
   </head>  
	
   <body> 
	
      <!-- Runtime errors from Silverlight will be displayed here. 
         This will contain debugging information and should be removed or hidden when 
         debugging is completed -->
			
      <div id = 'errorLocation' style = "font-size: small;color: Gray;"></div> 
		
      <h1 id = 'heading'></h1>
		
      <div id = "silverlightControlHost"> 
		
         <object data = "data:application/x-silverlight-2," 
            type = "application/x-silverlight-2" width = "100%" height = "100%"> 
				
            <param name = "source" value = "ClientBin/DomAccess.xap"/> 
            <param name = "onerror" value = "onSilverlightError" /> 
            <param name = "background" value = "white" /> 
            <param name = "minRuntimeVersion" value = "2.0.30923.0" /> 
            <param name = "autoUpgrade" value = "true" /> 
				
            <a href = "http://go.microsoft.com/fwlink/?LinkID=124807" 
               style = "text-decoration: none;"> 
               <img src = "http://go.microsoft.com/fwlink/?LinkId=108181" 
               alt = "Get Microsoft Silverlight" style = "border-style: none"/> 
            </a> 
				
         </object>
			
         <iframe style = 'visibility:hidden;height:0;width:0;border:0px'></iframe> 
			
      </div> 
		
   </body> 
	
</html>

위의 코드가 컴파일되고 실행되면 HTML 파일에서 가져온 모든 값이 출력 창에 표시됩니다.