Chrome Native Client 简介

Chrome Native Client 简介

目的:

Native Client是一种允许在浏览器中运行native compiled code 的技术,允许开发者运用自己熟悉的语言来开发web应用,而不只是JavaScript,目前NativeClient技术只能应用于google自己的chrome中。

一个使用Native client技术的web应用的组成:JavaScript,HTML, CSS, 和Native Client 模块,Native Client 模块:就是用Native语言编写的,供web调用的模块,目前NativeClient SDK只支持C和C++作为native 语言。

 Chrome Native Client 简介_第1张图片

应用场景:

1.      使用现有的已经存在的软件模块完成一个web 应用,而不需要换一种web语言来编写。

2.      一些传统桌面程序的迁移。

3.      多媒体应用的迁移。

4.      游戏应用的迁移。

 

Native client的工作原理:

一个Native Client应用主要分为3个组成部分:

1, HTML/JavaScriptapplication: 提供了用户界面和时间处理机制。

2, PepperAPI:  使得JavaScript code 和NativeClient module可以相互通信,同时允许Native Client 模块创建和管理浏览器相关的资源。

3, NativeClient module:  通常用于完成大量的计算,和大数据的操作。



下面看一下HTML/JavaScript和Native client Module之间的消息交互过程:

1.      Html/JavaScript代码向NativeClientModule 发送消息:

在HTML/JavaScript代码中以一个<embed>块表示NativeClient module, 例如:

<embed name="nacl_module"

          id="hello_world"

           width=0height=0

           src="hello_world.nmf"

           type="application/x-nacl"/>

在load 完native client 之后,就可以通过getElementByID(hello_world),来获得Nativeclient的句柄--helloworldModule,之后可以通过helloworldModule->PostMessage()向NativeClient发送消息。

2.      Html/JavaScript接收NativeClientModule发送的消息。

在html/JavaScript代码中,通过注册监听message消息,来实现对nativeClient消息的handle.

listener.addEventListener('message',handleMessage, true);

3.      NativeClient Module向html/javaScript发送消息。

在nativeClient端,以一个pp::Instance()来代表html/JavaScript实体, 于是NativeClientModule 就可以通过pp::Instance->PostMessage来向html/JavaScript端发送消息。

4.      NativeClient Module 接收html/javaScript消息。

可以通过pp::Instance()的hanleMessage()接口来处理发过过来的消息。

 

参考:

https://developers.google.com/native-client/overview?hl=zh-CN#intro

https://developers.google.com/native-client/devguide/tutorial#review

你可能感兴趣的:(JavaScript,Web,浏览器,chrome,Module,语言)