日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

詳解vue3的沙箱機制

瀏覽:27日期:2022-09-30 16:42:22
前言

vue3 沙箱主要分兩種

瀏覽器編譯版本,瀏覽器版本是使用with語法加上proxy代理攔截 本地預編譯版本,通過在模版預編譯階段轉換階段,使用轉換插件transformExpression將非白名單標識符掛在在組件代理對象下 瀏覽器編譯版本

render 函數編譯結果

<div>{{test}}</div><div>{{Math.floor(1)}}</div>

to

const _Vue = Vue;return function render(_ctx, _cache, $props, $setup, $data, $options) { with (_ctx) { const { toDisplayString: _toDisplayString, createVNode: _createVNode, Fragment: _Fragment, openBlock: _openBlock, createBlock: _createBlock, } = _Vue; return ( _openBlock(), _createBlock(_Fragment,null,[ _createVNode('div', null, _toDisplayString(test), 1 /* TEXT */), _createVNode( 'div', null, _toDisplayString(Math.floor(1)), 1 /* TEXT */ ),],64 /* STABLE_FRAGMENT */ ) ); }};

從上面的代碼,我們能發現,變量標識符沒有增加前綴,只是用with語法包裹了一下,延長作用域鏈,那么是如何做到 js 沙箱攔截的呢?例如變量test, 理論上說,當前作用域鏈沒有test變量,變量會從上一層作用域查找,直到查找到全局作用域,但是,實際上只會在_ctx上查找, 原理很簡單,_ctx是一個代理對象,那么我們如何使用Proxy做攔截,示例代碼如下:

const GLOBALS_WHITE_LISTED = 'Infinity,undefined,NaN,isFinite,isNaN,parseFloat,parseInt,decodeURI,' + 'decodeURIComponent,encodeURI,encodeURIComponent,Math,Number,Date,Array,' + 'Object,Boolean,String,RegExp,Map,Set,JSON,Intl,BigInt';const isGloballyWhitelisted = (key) => { return GLOBALS_WHITE_LISTED.split(',').includes(key);};const hasOwn = (obj, key) => { return Object.prototype.hasOwnProperty.call(obj, key);};const origin = {};const _ctx = new Proxy(origin, { get(target, key, reciever) { if (hasOwn(target, key)) { Reflect.get(target, key, reciever); } else { console.warn(`Property ${JSON.stringify(key)} was accessed during render ` + `but is not defined on instance.` ); } }, has(target, key) { // 如果是 全局對象 返回false,不觸發get 攔截,從上一層作用域查找變量 // 如果不是 全局對象 返回true,觸發get 攔截 return !isGloballyWhitelisted(key); },});

代碼很簡單,為什么這么簡單的代碼就能做到攔截? 因為 with 語句會觸發 has 攔截,當 has 返回 true,就會 觸發代理對象 get 攔截,如果返回 false, 則代理對象 get 攔截不會觸發,變量不在當前代理對象查找,直接查找更上一層作用域

本地預編譯版本

<div>{{test}}</div><div>{{Math.floor(1)}}</div>

to

import { toDisplayString as _toDisplayString, createVNode as _createVNode, Fragment as _Fragment, openBlock as _openBlock, createBlock as _createBlock,} from 'vue';export function render(_ctx, _cache, $props, $setup, $data, $options) { return ( _openBlock(), _createBlock( _Fragment, null, [_createVNode('div', null, _toDisplayString(_ctx.a), 1 /* TEXT */),_createVNode( 'div', null, _toDisplayString(Math.floor(1)), 1 /* TEXT */), ], 64 /* STABLE_FRAGMENT */ ) );}

從上面的代碼我們可以發現,非白名單標識符都添加了_ctx 變量前綴,那么是如何做到的呢?當本地編譯 template 時,處于轉換階段時會對 變量表達式節點NodeTypes.SIMPLE_EXPRESSION進行添加前綴處理,示例代碼如下:

const GLOBALS_WHITE_LISTED = 'Infinity,undefined,NaN,isFinite,isNaN,parseFloat,parseInt,decodeURI,' + 'decodeURIComponent,encodeURI,encodeURIComponent,Math,Number,Date,Array,' + 'Object,Boolean,String,RegExp,Map,Set,JSON,Intl,BigInt';const isGloballyWhitelisted = (key) => { return GLOBALS_WHITE_LISTED.split(',').includes(key);};const isLiteralWhitelisted = (key)=>{ return ’true,false,null,this’.split(’,’).includes(key)}export function processExpression( node) { const rewriteIdentifier = (raw) => { return `_ctx.${raw}` } const rawExp = node.content if (isSimpleIdentifier(rawExp)) { const isAllowedGlobal = isGloballyWhitelisted(rawExp) const isLiteral = isLiteralWhitelisted(rawExp) if (!isAllowedGlobal && !isLiteral) { node.content = rewriteIdentifier(rawExp) } return node }

當然上面的代碼只是簡化版本,原版插件還做了精確到了__props $setup,減短變量查詢路徑,提高性能,還有通過babel編譯復雜表達式比如:箭頭函數。

總結

整個 vue3 js 沙箱機制就解釋結束了,當初瀏覽器編譯版本困擾了我很久,因為不知道 has 可以攔截 with 語句變量查詢

以上就是詳解vue3的沙箱機制的詳細內容,更多關于vue3 沙箱機制的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
九九99久久精品在免费线bt| 欧美激情99| 国产视频一区欧美| 亚洲精品在线a| 欧美日韩xxxx| 牛牛精品成人免费视频| a天堂资源在线| 欧美精选一区二区三区| 日韩在线卡一卡二| 国产精品视频3p| 91精品一区国产高清在线gif| 免费视频一区三区| 日本欧美在线看| 日欧美一区二区| 精品国产亚洲日本| 男女精品网站| 中文字幕在线视频网站| 久久理论电影| 玖玖玖国产精品| 日本欧美在线看| 日韩av午夜在线观看| 国产精品调教| 偷拍精品精品一区二区三区| 国产精品99一区二区| 玖玖精品视频| 久久gogo国模啪啪裸体| 98精品视频| 欧美亚洲精品在线| 亚洲综合中文| 国产激情久久| 91精品推荐| 日本综合精品一区| 日韩免费久久| 精品视频在线你懂得| 国产一区二区三区久久久久久久久| 精品免费在线| 亚洲黄色免费看| 另类激情亚洲| 国产免费av一区二区三区| 麻豆国产欧美一区二区三区| 国产精品久久久久av电视剧| 先锋影音国产一区| 福利在线一区| 成人羞羞在线观看网站| 国产精品女主播一区二区三区| 国产99亚洲| 欧美在线亚洲| 日韩精品一区二区三区中文在线 | 美女少妇全过程你懂的久久| 妖精视频成人观看www| 日本亚洲欧美天堂免费| 国产亚洲久久| 最新中文字幕在线播放| 麻豆久久精品| 国产专区精品| 免费久久99精品国产| 精品中文在线| 一本一本久久| 久久一区国产| 天堂成人免费av电影一区| 国产精品亚洲欧美一级在线| 欧美不卡高清一区二区三区| 免费的成人av| 精品欧美视频| 综合日韩在线| 手机在线电影一区| 日本在线视频一区二区| 中文在线а√天堂| 日韩av中文字幕一区二区| 欧美色图国产精品| 麻豆成人在线观看| 亚洲欧洲专区| 宅男在线一区| 日韩av有码| 日韩欧美久久| 中文亚洲欧美| 人在线成免费视频| 亚洲人成网站在线在线观看| 中文在线资源| 欧美黑人巨大videos精品| 免费久久99精品国产| 久久婷婷av| 精品久久久久中文字幕小说| 日韩中文字幕在线一区| 精品中文字幕一区二区三区av| 天堂资源在线亚洲| 日本强好片久久久久久aaa| 婷婷激情久久| 国产精品国产一区| 欧美片第1页综合| 久久高清免费观看| 午夜免费一区| 日韩伦理在线一区| 麻豆精品视频在线观看免费| 日韩精品久久理论片| 石原莉奈在线亚洲二区| 国精品一区二区| 色网在线免费观看| 九九九精品视频| 国产精品成人国产| 日本不卡视频在线| 一区二区三区国产在线| 亚洲激情黄色| 午夜精品婷婷| 欧美日韩在线二区| 亚洲成人精品| 性感美女一区二区在线观看| 精品国产精品久久一区免费式 | 日本精品一区二区三区在线观看视频| 亚洲ab电影| 国产精品7m凸凹视频分类| 在线一区视频| 日韩午夜av| 在线看片日韩| 日韩国产一二三区| 国产精品毛片久久久| 69堂精品视频在线播放| 精品视频国内| 久久久91麻豆精品国产一区| 欧美黑人做爰爽爽爽| 免费一级欧美片在线观看网站| 色天使综合视频| 日韩欧美自拍| 欧美在线亚洲| 亚洲免费网址| 日韩欧美中文字幕在线视频| 国产精品最新| 日韩精品永久网址| 日韩亚洲精品在线| 欧美一区二区三区久久精品| 国内不卡的一区二区三区中文字幕 | 成人在线免费观看91| 日韩欧美精品| 日韩影院在线观看| 国产日产精品一区二区三区四区的观看方式| 国产精品av一区二区| 999精品在线| 巨乳诱惑日韩免费av| 国产亚洲一区二区三区啪| 黄色欧美在线| 午夜久久99| 国产探花在线精品| 日韩一区二区三区在线免费观看| 国产精品99免费看| 精品一级视频| 日韩欧美字幕| 国产亚洲午夜| 日韩欧美激情电影| 日韩高清在线一区| 欧美+亚洲+精品+三区| 亚洲精品激情| 夜鲁夜鲁夜鲁视频在线播放| 日韩视频精品在线观看| 国产视频一区二| 亚洲一级影院| 国产精品亲子伦av一区二区三区| 日本成人中文字幕在线视频| 你懂的国产精品永久在线| 欧美国产偷国产精品三区| 国产精品女主播一区二区三区| 日韩视频二区| 国产亚洲久久| 久久一区二区三区喷水| 日韩av一区二区三区四区| 精精国产xxxx视频在线播放| 蜜臀va亚洲va欧美va天堂| 成人精品动漫一区二区三区| 香蕉久久夜色精品国产| 精品国产一区二| 免费精品视频最新在线| www.51av欧美视频| 日日摸夜夜添夜夜添国产精品| 亚洲欧美视频一区二区三区| 97在线精品| 日韩成人一级| 色综合www| 国产欧美一区二区色老头| 欧美日韩一区二区三区视频播放| 图片区亚洲欧美小说区| 欧美有码在线| 欧美中文字幕一区二区| 国产精品亚洲四区在线观看| 欧美日韩免费观看一区=区三区 | 日韩一区精品| 精品成人免费一区二区在线播放| 精品丝袜在线| 欧美黄色一区二区| 成人羞羞视频在线看网址| 青草综合视频| 久久要要av| 国产精品hd| 午夜久久影院| 国产欧美日韩在线观看视频| 在线看片日韩| 午夜精品久久久久久久久久蜜桃| 亚洲永久av| 国产亚洲电影| 亚洲免费资源| 在线午夜精品| 精品欧美久久|