34 lines
		
	
	
		
			705 B
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			34 lines
		
	
	
		
			705 B
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # babel-traverse
 | |
| 
 | |
| > babel-traverse maintains the overall tree state, and is responsible for replacing, removing, and adding nodes.
 | |
| 
 | |
| ## Install
 | |
| 
 | |
| ```sh
 | |
| $ npm install --save babel-traverse
 | |
| ```
 | |
| 
 | |
| ## Usage
 | |
| 
 | |
| We can use it alongside Babylon to traverse and update nodes:
 | |
| 
 | |
| ```js
 | |
| import * as babylon from "babylon";
 | |
| import traverse from "babel-traverse";
 | |
| 
 | |
| const code = `function square(n) {
 | |
|   return n * n;
 | |
| }`;
 | |
| 
 | |
| const ast = babylon.parse(code);
 | |
| 
 | |
| traverse(ast, {
 | |
|   enter(path) {
 | |
|     if (path.isIdentifier({ name: "n" })) {
 | |
|       path.node.name = "x";
 | |
|     }
 | |
|   }
 | |
| });
 | |
| ```
 | |
| [:book: **Read the full docs here**](https://github.com/thejameskyle/babel-handbook/blob/master/translations/en/plugin-handbook.md#babel-traverse)
 |