dsu*_*rsl 5 javascript coffeescript jsdom d3.js
我想从命令行执行一些d3代码.最初我尝试过类似的东西:
task 'data', 'Build some data with d3', ->
d3 = require('lib/d3.v2')
console.log "d3 version = "+ d3.version
Run Code Online (Sandbox Code Playgroud)
但这没效果.我得到这样的错误:
node.js:201
throw e; // process.nextTick error, or 'error' event on first tick
^
ReferenceError: CSSStyleDeclaration is not defined
at /Users/mydir/Documents/classes/middleclass/app/lib/d3.min.js:1:21272
at Object.<anonymous> (/Users/mydir/Documents/classes/middleclass/app/lib/d3.min.js:2:25395)
at Module._compile (module.js:432:26)
at Object..js (module.js:450:10)
at Module.load (module.js:351:31)
at Function._load (module.js:310:12)
at Module.require (module.js:357:17)
at require (module.js:368:17)
at Object.action (/Users/mydir/Documents/classes/middleclass/Cakefile:22:10)
at /usr/local/lib/node_modules/coffee-script/lib/coffee-script/cake.js:39:26
Run Code Online (Sandbox Code Playgroud)
所以......我认为这个异常告诉我需要在浏览器中执行d3.我试过几种不同的方式.基本上,我想如果我只是激发了幻影,我可能会做我想做的事情.这是我的Cakefile:
task 'data2', 'Build some data with d3', ->
hem = spawn 'hem', ['server']
phantom = require('phantom')
phantom.create (ph) ->
ph.createPage (page) ->
page.open 'http://localhost:9294/sandbox.html', (status) ->
page.evaluate (-> window), (window) ->
require = window.require
require('lib/d3.v2')
console.log("d3 version = "+ d3.version)
ph.exit()
hem.kill()
Run Code Online (Sandbox Code Playgroud)
当我走这条路时,我总是得到这样的例外:
TypeError: object is not a function
at Object.CALL_NON_FUNCTION (native)
at Object.<anonymous> (/Users/mydir/Documents/classes/middleclass/Cakefile:52:13)
at Object.<anonymous> (/Users/mydir/Documents/classes/middleclass/node_modules/phantom/node_modules/dnode-protocol/index.js:274:16)
at apply (/Users/mydir/Documents/classes/middleclass/node_modules/phantom/node_modules/dnode-protocol/index.js:143:17)
at EventEmitter.handle (/Users/mydir/Documents/classes/middleclass/node_modules/phantom/node_modules/dnode-protocol/index.js:120:13)
at /Users/mydir/Documents/classes/middleclass/node_modules/phantom/node_modules/dnode-protocol/index.js:81:20
at EventEmitter.<anonymous> (/Users/mydir/Documents/classes/middleclass/node_modules/phantom/node_modules/dnode/node_modules/lazy/lazy.js:62:13)
at EventEmitter.<anonymous> (/Users/mydir/Documents/classes/middleclass/node_modules/phantom/node_modules/dnode/node_modules/lazy/lazy.js:46:19)
at EventEmitter.emit (events.js:67:17)
at EventEmitter.<anonymous> (/Users/mydir/Documents/classes/middleclass/node_modules/phantom/node_modules/dnode/node_modules/lazy/lazy.js:46:39)
Run Code Online (Sandbox Code Playgroud)
我做错了什么?
感谢mbostock,我得到了以下工作:
我的package.json:
{
"name": "app",
"version": "0.0.1",
"dependencies": {
"d3": "~2.8.0",
"jsdom": "~0.2.13"
}
}
Run Code Online (Sandbox Code Playgroud)
我的蛋糕文件:
task 'd3', 'Do something with d3', ->
jsdom = require('jsdom')
jsdom.env({
html: 'public/sandbox.html'
done: (errors,window) ->
require('d3/index.js')
console.log("d3 version = "+ d3.version)
})
Run Code Online (Sandbox Code Playgroud)
请参阅 D3 的package.json。更具体地说,在 Node 或类似环境中运行时需要的文件是index.js而不是 d3.v2.js;该文件包含一些使 D3 与require
操作员兼容的特殊补丁。
要亲自尝试一下,cd
请在 d3 存储库中运行node
以创建交互式 shell,然后输入
var d3 = require("./");
Run Code Online (Sandbox Code Playgroud)
或者,如果您在自己的项目文件夹中,如果您已通过 npm ( npm install d3
) 将 D3 安装到了 node_modules/d3 中,您可以说:
var d3 = require("d3");
Run Code Online (Sandbox Code Playgroud)