Babylon-AST初探-代碼更新刪除(Update Remove)

??通過前兩篇文章的介紹,大家已經了解了CreateRetrieve,我們接著介紹UpdateRemove操作。Update操作通常配合Create來完成。我們這篇文章主要介紹幾個常用的NodePath`APIreplaceinsertremove`。具體也可以看babel-handbook中的Manipulation章節。

replaceWith 使用新的節點進行替換

將加法運算替換成乘法

const code = `const c = a + b`
const ast = babylon.parse(code)traverse(ast, {BinaryExpression(path) {// 注意這里要有判斷,否則會無限進入`BinaryExpression`// https://stackoverflow.com/questions/37539432/babel-maximum-call-stack-size-exceeded-while-using-path-replacewithif (path.node.operator === '+') {path.replaceWith(t.binaryExpression('*', path.node.left, path.node.right))}}
})console.log(generate(ast, {}, code).code) // const c = a * b;

this.count替換為this.data.count

??轉換前后的AST展示如下圖:

圖片描述

??我們需要做的是,找到符合this.countThisExpression,然后把它替換為this.data

const code = `this.count`
const ast = babylon.parse(code)traverse(ast, {MemberExpression(path) {if (t.isThisExpression(path.node.object) &&t.isIdentifier(path.node.property, {name: 'count'})) {path.get('object')    // 獲取`ThisExpresssion`.replaceWith(t.memberExpression(t.thisExpression(), t.identifier('data')))}}
})
console.log(generate(ast, {}, code).code) // this.data.count;

replaceWithSourceString 直接使用代碼替換

??上個例子中將this.count替換為this.data.count的部分,通過t.memberExpression可以構造node。更簡單的操作可以直接使用replaceWithSourceString,個人覺得這個API很好用。

path.get('object').replaceWithSourceString('this.data')

插入操作

??插入是樹操作的一種常見操作。子節點是個Array,前、中、后各種位置都可以插入新節點。下面來介紹下pushContainerunshiftContainerinsertBeforeinsertAfter操作。

??這里以給obj對象新增一個屬性myprop: 'hello my property'為例:

const code = `
const obj = {count: 0,message: 'hello world'
}
`
const ast = babylon.parse(code)const property = t.objectProperty(t.identifier('myprop'),t.stringLiteral('hello my property')
)

pushContainer 父節點的操作

??父節點為子節點Array插入一個node

traverse(ast, {ObjectExpression(path) {path.pushContainer('properties', property)}
})

insertAfter 兄弟節點的操作

??insertAfter也可以完成上述操作,需要找到message屬性,然后在后面插入node就搞定啦

traverse(ast, {ObjectProperty(path) {if (t.isIdentifier(path.node.key, {name: 'message'})) {path.insertAfter(property)}}
})

??unshiftContainerinsertBefore與上面兩個相對應,這里不再舉例了,大家可以自己試一試。

??因為properties是個數組,因此,我們可以直接使用數組操作

traverse(ast, {ObjectExpression(path) {// path.pushContainer('properties', property)path.node.properties.push(property)}
})

Remove 自我毀滅

??Remove方法極為簡單,找到要刪除的NodePath,執行Remove就結束了。如上述代碼,我們要刪除message屬性,代碼如下:

traverse(ast, {ObjectProperty(path) {if (t.isIdentifier(path.node.key, {name: 'message'})) {path.remove()}}
})

到目前為止,AST的CURD我們都介紹完了,下面一篇文章以vue小程序為例,我們來實戰一波。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/538538.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/538538.shtml
英文地址,請注明出處:http://en.pswp.cn/news/538538.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

python中時間間隔默認單位是什么_Python時間增量(以年為單位)

你需要不止一個timedelta來說明多少年過去了;你還需要知道開始(或結束)日期。(這是閏年的事。)最好的方法是使用dateutil.relativedeltaobject,但這是第三方模塊。如果您想知道從某個日期起的datetime年(默認為現在),可以執行以下操作&#x…

編解碼異常分析

前言 最近在做的項目,有H264解碼的需求。部分H264文件解碼播放后,顯示為綠屏或者花屏。 分析 如何確認是否是高通硬解碼的問題 adb 指令 adb root adb remount adb shell setenforce 0 adb shell setprop vendor.gralloc.disable_ubwc 1 adb shell c…

python讀取數據庫導出文件_python如何導出excel表格數據庫數據

{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":4,"count":4}]},"card":[{"des":"阿里云數據庫專家保駕護航,為用戶…

mysql堆溢出_為什么這個MySQL觸發器會導致堆棧溢出?

我今天遇到了同樣的問題,每次觸發都會導致堆棧溢出.原來我的Zend社區服務器安裝附帶了一個默認的my.cnf文件,其中thread_stack大小設置為128K,這導致每個線程中可用于堆棧的131072字節:mysql> show variables where Variable_name thread_stack;---------------…

MySQL定義數據庫對象之指定definer

mysql創建view、trigger、function、procedure、event時都會定義一個Definer: SQL SECURITY 有兩個選項,一個為DEFINER,一個為INVOKER;SQL SECURITY { DEFINER | INVOKER } :指明誰有權限來執行。DEFINER 表示按定義者擁有的權限來…

js根據name獲取value_js 函數的重載

js 函數的重載我們知道,很多編程語言都有函數的重載。所謂的重載,看定義:重載,簡單說,就是函數或者方法有相同的名稱,但是參數列表不相同的情形,這樣的同名不同參數的函數或者方法之間&#xff…

python調用菜單響應事件_[Python] wxpython 編程觸發菜單或按鈕事件

最近逐步熟悉wxpython,編寫了幾個小小功能的GUI程序,GUI中免不了會有在代碼中觸發控件事件的業務需求。在其他Gui界面的語言中有postevent、triggerevent 調用事件名稱的函數,非常方便。在wxpython里如何解決呢,上一段簡單的代碼。…

Angular CLI 使用教程指南參考

原文鏈接:http://www.cnblogs.com/bh4lm/p/6638057.html 點擊閱讀原文 ----------------------------------------------- Angular CLI 使用教程指南參考 Angular CLI 現在雖然可以正常使用但仍然處于測試階段. Angular CLI 依賴 Node 4 和 NPM 3 或更高版本. 安裝…

存儲過程循環遍歷一個月的每一天的函數_JavaScript 循環:如何處理 async/await

同步循環很久以前我寫的循環是這樣的:后來 JavaScript 提供了很多新的特性,現在我們會更傾向于用下面這種寫法:在開發過程可能會有這么一種需求,我們需要在循環中異步處理 item,那么可以怎么做呢?異步循環如…

Angular程序架構

component,組件是Angular應用的基本構建塊,你可以把一個組件理解為一段帶有業務邏輯和數據的html。組件下面可以有子組件,子組件下有孫子組件,像樹一樣。指令:允許你向html元素添加自定義行為。模塊Ngmodule&#xff1…

sqllite能連接mysql_SQLLite 可以通過SQL語言來訪問的文件型SQL數據庫

Web Storage分為兩類:- sessionStorage:數據保存在session 對象中(臨時)- localStorage:數據保存在本地硬件設備中(永久)sessionStorage:保存數據的兩種方法:sessionStorage.setItem(key,val);sessionStorage.key val;讀取數據的…

迭代器模式(Iterator)

迭代器模式 一. 迭代器模式 1.1 定義 提供一種方法順序訪問一個集合對象中的各種元素,而又不暴露該對象的內部表示.1.2 角色 抽象迭代器接口(Iterator).具體迭代器(ConcreteIterator).抽象聚合接口(Aggrega…

Angular啟動過程介紹

1、啟動時加載了哪個頁面?2、啟動時加載了哪些腳本?3、這些腳本做了什么事?打開Angular的命令行文件.angular-cli.json。apps節點下面。首先加載 index.html 頁面。此時瀏覽器顯示index.html的內容。再加載main.ts腳本"apps": [{..…

python解壓打開文件過多_在python中使用zipfile壓縮文件時層級很多,有很多層目錄...

如下圖本來只壓縮一個文件結果這個文件所在的路徑全都被壓縮進去啦下面是解決方法yadirD:/databak/zipfilepathD:/zipfile.zipfilelists os.listdir(yadi)if filelists None or len(filelists) print (">>>>>>待壓縮的文件目錄:" ya…

易語言python1.1模塊_易語言之編寫模塊與引入模塊

本人并不精通易語言,只是對其進行一定了解后做一個簡單的總結。直接新建一個易語言模塊,然后添加子程序即可。子程序當然可以隨意命名,實際上,易語言的子程序就和c語言的函數,java中的方法一樣(實際上,java…

spring boot開發筆記——mybatis

概述 mybatis框架的優點,就不用多說了,今天這邊干貨主要講mybatis的逆向工程,以及springboot的集成技巧,和分頁的使用 因為在日常的開發中,當碰到特殊需求之類會手動寫一下sql語句,大部分的時候完全可以用m…

Angular項目目錄介紹

通過 ng new 項目名生成的項目 一級目錄 Angular cli 工具生成的目錄文件名不要隨意修改,要不然會影響工具的使用。e2e:端到端的測試目錄,用來做自動測試的。node_modules:Angular第三方包。src:應用源代碼目錄&#…

jvm內存模型_四種視角看JVM內存模型

1.JVM運行視角程序計數器Java虛擬機棧本地方法棧Java堆方法區1 .程序計數器程序計數器是一塊較小的內存空間,它可以看作是當前線程所執行的行號指示器。這個計數器記錄的是正在執行的虛擬機字節碼指令的地址。此內存區域是唯一一個在JAVA虛擬機規范中沒有規定任何Ou…

linux mysql失敗_linux下登陸mysql失敗

標簽:一.提示由于沒有密碼,拒絕登陸ERROR 1045 (28000): Access denied for user ‘root‘‘localhost‘ (using password: NO)1.關閉mysql# service mysqld stop2.屏蔽權限# mysqld_safe --skip-grant-table屏幕出現: Starting demo from ..…

Tomcat服務腳本

為什么80%的碼農都做不了架構師?>>> #!/bin/bash ### BEGIN INIT INFO # Provides: tomcat # Required-Start: $remote_fs $syslog # Required-Stop: $remote_fs $syslog # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # S…