一个用JavaScript生成思维导图(mindmap)的github repo
github 地址:https://github.com/dundalek/markmap
作者的readme写得很简单。
今天有同事问作者提供的例子到底怎么跑。这里我就写一个更详细的步骤出来。
首先查看example.parse.js的内容:
var fs = require('fs');
var parse = require('../parse.markdown');
var transform = require('../transform.headings');
var text = fs.readFileSync('gtor.md', 'utf-8');
var headings = parse(text);
var root = transform(headings);
console.log(root);
fs.writeFileSync('gtor.json', JSON.stringify(root));
使用nodejs命名node example.parse.js执行这段代码:代码读取包含思维导图的本地文件gtor.md, 解析并转换生成本地文件gtor.json.
然后查看example.view.js, 发现作者使用了d3来做UI的渲染。
d3.json("gtor.json", function(error, data) {
if (error) throw error;
markmap('svg#mindmap', data, {
preset: 'default', // or colorful
linkShape: 'diagonal' // or bracket
});
});
如果直接双击examples文件夹里的index.html文件在浏览器里打开,会出现跨域错误导致本地文件gtor.json无法访问:
必须把这个example部署到服务器上运行才行。
为了简单起见,我做了一个简单的封装。如果您想跑跑例子看看效果,只需要下载我的project到本地:https://github.com/i042416/jerrylist
直接在本地用nodejs 命令行启动服务器:
node local.js
然后localhost:3000/mindmap即可看到思维导图的效果
SAP Engagement Center UI的这个按钮会每秒钟刷新一次,显示页面已经打开了多长时间。
需求:需要找到哪行JavaScript代码不断刷新的按钮文字。
按照经验判断,这个文字肯定是一个JavaScript function通过setTimeout每隔一秒执行的。如何快速找到这个function以及setTimeout的调用位置呢?
1. 利用Chrome开发者工具的Elements标签页功能,找到该按钮HTML源代码对应的标签。
2. 右键单击该标签,选择Break on->subtree modification:
一秒钟之后,断点会自动触发,停留在该元素的innerHTML发生变化的代码位置。从代码478我们得知,UI上按钮的文字能够刷新,是因为其dom元素的innerHTML属性被修改的缘故。
从调用栈也能迅速找到setTimeout的调用位置和调用间隔(1秒)
更多Jerry的Chrome开发者工具使用心得,请参考Jerry的公众号文章:Jerry和您聊聊Chrome开发者工具
有朋友问到User Status profile中Business Transaction字段的用途,如下图INPR, FINI所示。
实际上,这个字段作为一个桥梁,连接了User Status和System Status。
以上图的INPR为例,其User Status code为PROC - 处理中。到TJ30查表可得其User Status为E0002。
使用事务码BS33,找到INPR,选择Follow-up actions:
得到Business Transaction INPR的如下follow-up actions列表。下图意思是,一旦用户在UI上选择了In Process这个User Status(E0002 ),那么这个订单的System Status会被置为I1003,因为下图I1003对应的Set列被置位,而Delete处于非置位状态。
这也就是为什么到表CRM_JEST里,对于同一条订单,能发现其拥有1个System Status I1003和User Status E0002的原因。
- 点赞
- 收藏
- 关注作者
评论(0)