如何使用 Browserify & iOS JavaScriptCore

Posted

技术标签:

【中文标题】如何使用 Browserify & iOS JavaScriptCore【英文标题】:How to use Browserify & iOS JavaScriptCore 【发布时间】:2014-06-29 14:45:58 【问题描述】:

给定一个不依赖任何 Node.js 功能的 Node.js 模块,除了 modules (export/require) 我如何使用 JS 核心从 Objective-C 或 Swift 访问它的功能?

“模块”示例:

var compute = function compute(number) 
  return 2 * number
;

exports.compute = compute;

浏览包(bundle.js):

(function e(t,n,r)function s(o,u)if(!n[o])if(!t[o])var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);throw new Error("Cannot find module '"+o+"'")var f=n[o]=exports:;t[o][0].call(f.exports,function(e)var n=t[o][1][e];return s(n?n:e),f,f.exports,e,t,n,r)return n[o].exportsvar i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s)(1:[function(require,module,exports)

var compute = function compute(number) 
  return 2 * number
;

exports.compute = compute;

,],,[1])

Swift 代码:

下面的代码似乎无法在bundle.js 中找到compute 函数——resultNaN

var path = b.pathForResource("bundle", ofType: "js")
var source : String = NSString.stringWithContentsOfFile(path, encoding: NSUTF8StringEncoding, error: nil)
var context = JSContext()
context.evaluateScript(source)
let compute = context.objectForKeyedSubscript("compute")
let value = compute.callWithArguments([42])
var result = value.toNumber()

如何访问“已浏览”的 javascript 函数?

【问题讨论】:

这个问题你解决了吗? 【参考方案1】:

thejh 对相关问题here 的回答解释说,默认情况下,browserify 不允许您从 browserified 代码之外访问函数和模块。他的回答展示了如何在“窗口”级别定义包装函数,然后您可以从 ObjC / Swift 调用这些函数

【讨论】:

以上是关于如何使用 Browserify & iOS JavaScriptCore的主要内容,如果未能解决你的问题,请参考以下文章

Browserify & ReactJS 问题

将 Browserify 与 Reactjs 一起使用

前端模块化开发学习之gulp&amp;browserify篇

如何使用 browserify 和 gulp 输出多个包

使用browserify时如何在AngularJS中包含jQuery?

在带有 Browserify 的 ES6 中使用 Bootstrap 和 jQuery 包时出错