Native Function, WTF?

How to enhance your browser

内容

  • 为什么
  • 哪些方法
  • 如何实现

Native Function

Number.parseInt.toString()
> "function parseInt() { [native code] }"

Native Function

class Script: public Struct {
 public:
  // Script types.
  enum Type {
    TYPE_NATIVE = 0,
    TYPE_EXTENSION = 1,
    TYPE_NORMAL = 2,
    TYPE_WASM = 3,
    TYPE_INSPECTOR = 4
  };

  ...
Handle<String> JSFunction::ToString(Handle<JSFunction> function) {
  Isolate* const isolate = function->GetIsolate();
  Handle<SharedFunctionInfo> shared_info(function->shared(), isolate);

  // Check if {function} should hide its source code.
  if (!shared_info->IsUserJavaScript()) {
    return NativeCodeFunctionSourceString(shared_info);
  }

  ...

为什么要扩充浏览器的功能

  • 实现新规范
  • 使用中浏览器内核无法提供的能力
  • 自定义扩展机制
  • 第三方浏览器或 webview
  • 集成其他宿主环境
  • ...

浏览器中供 JavaScript 使用的原生功能的来源

  • 脚本引擎 (ECMA, extension)
  • 渲染引擎 (DOM, BOM, CSSOM, HTML5...) 
  • 扩展 (浏览器扩展机制, devtools) 
  • 引入的其他宿主环境 (Node...) 

从脚本引擎进行扩展

增加原生接口

v8::Extension(kLoadTimesExtensionName,
      "var chrome;"
      "if (!chrome)"
      "  chrome = {};"
      "chrome.loadTimes = function() {"
      "  native function GetLoadTimes();"
      "  return GetLoadTimes();"
      "};"
      "chrome.csi = function() {"
      "  native function GetCSI();"
      "  return GetCSI();"
      "}") {}

      ...

实操:增加一个 JavaScript 接口

chrome.date = function() {
    return Date();
};

对渲染引擎功能的扩充

实操:增加 timing 接口属性

  • IDL
    • readonly attribute unsigned long long firstLayout;
  • Implementation
ScriptValue PerformanceTiming::toJSONForBinding
        (ScriptState* scriptState) const
{
    ...
    result.addNumber("firstLayout", firstLayout());
    return result.scriptValue();
}

扩展开发者工具

集成 Node

Chromium + Node

  • node-webkit -> nw.js
  • heX -> dead
  • atom-shell -> Electron

Node 的构成

  • node
    • V8
    • libuv
    • openssl
    • ...

Node 的启动过程

加入 Node 的同步逻辑

  • DidCreateScriptContext
    • init
    • process
    • start node.js
  • WillReleaseScriptContext
    • dispose
    • exit

整合 Node 的异步

  • heX
    • browser message loop (浏览器进程) 中通知 (IPC) uv_run_once (渲染进程)
  • Electron

比较

脚本引擎扩展 渲染引擎 V8 API扩展 其他宿主
Pros 开发成本低
结构简单
可访问内核资源多
IDL 规范
接口标准
可访问内核资源多
开发成本低
可访问内核资源多
功能强大
扩展性
学习成本低
Cons 接口类型简单 build 时间长
直接修改内核
直接修改内核 开发、维护成本高
结构复杂

谢谢

nf_wtf

By luyuan

nf_wtf

Native Function, WTF?

  • 1,634