摘要:本周在支持機票的項目中對做了大量改進,包括性能上與結構上的改進。但通過一些簡化改改良,代碼的可靠性大大提高了。此外,還有周邊的優化在目錄下提供一個,用于在舊式中替換。改善,里面內置了一個補丁,也是用于改善性能,或中的性能好差。
本周在支持機票的項目中對anujs做了大量改進,包括性能上與結構上的改進。與1.1.3一樣,還是差一個組件就完全兼容阿里的antd UI庫。
框架本身的改進有:
修正flushUpdaters中updater對象的泄露問題(需要clearArray一下)
優化diffChildren的邏輯,防止出現parentNode等于null的情況(比如為文本節點取firstChild)
簡化ControlledComponent與dispose模塊
處理updateElement方法中兩個虛擬DOM的引用一樣時,調用flattenChildren時,舊的vchildren丟失的情況
移除Refs中的createStringRef,createInsanceRef,添加fireRef,
重構detachRef,clearRefs,cloneElement,createElement有關ref的部分,盡量減少閉包的應用
將updateQueue移出所有diff方法的傳參列表,合并到調度器中
新添React16的createPortal API
上面什么修正內存泄露與減少閉包,都是在IE下才發現的問題,在chrome下一點事都沒有。但通過一些簡化改改良,代碼的可靠性大大提高了。
此外,還有周邊的優化
在lib目錄下提供一個ReduxIE.js,用于在舊式IE中替換redux。因為官方redux里面用到了一個isPlainObject方法,這個方法是由lodash庫提供的,而這個方法的源碼本身是來源于jQuery3.x,沒有針對IE進行處理,性能很差。我將它替換為jQuery1.x的isPlainObject,就很正常運作了。
改善ReactIE.js,里面內置了一個Object.keys補丁,也是用于改善性能,es5shim.js或babel polyfill中的Object.keys性能好差。
function needFix(fn) { return !/native code/.test(fn); } function keysPolyfill() {//解決IE下Object.keys的性能問題 if (needFix(Object.keys)) { Object.keys = function(obj) { var a = []; for(var k in obj) { if (obj.hasOwnProperty(k)) { a.push(k); } } return a; }; } } keysPolyfill(); setTimeout(keysPolyfill, 0); setTimeout(keysPolyfill, 100);
使用
npm i anujs
或者使用架手架 https://github.com/Levan-Du/a...
npm i -g anu-cli
webpack.config中如何代替原來用React編寫的項目
resolve: { alias: { "react": "anujs", "react-dom": "anujs", // 若要兼容 IE 請使用以下配置 // "react": "qreact/dist/ReactIE", // "react-dom": "qreact/dist/ReactIE", // 如果引用了 prop-types 或 create-react-class // 需要添加如下別名 "prop-types": "qreact/lib/ReactPropTypes", "create-react-class": "qreact/lib/createClass" //如果你在移動端用到了onTouchTap事件 "react-tap-event-plugin": "anujs/lib/injectTapEventPlugin", } },
歡迎大家為anujs加星星與試用!?。?/p>
https://github.com/RubyLouvre...
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/89199.html
摘要:是一款高性能框架,是目前世界上對兼容最好的迷你庫。自起,相繼推出,與等新,表明官方正積極由純庫向大而全的框架演變,它將會越來越好用。一些迷你庫可能跟不上步伐,現在也只有有這實力跟進。 anujs1.3.0是一款高性能React-like框架,是目前世界上對React16兼容最好的迷你庫。 自React16起,相繼推出createContext,createPortal, createR...
摘要:現在只差一個組件就完全支持阿里的庫了。一共跑通個測試應該是全世界最接近官方的迷你框架了。以后的工作就是把的一些新特性支持了,包括組件返回數字字符串數組,鉤子與。隨著代碼的增加,我會將一些廢棄的方法拆分出來。在打包時,根據你們的喜好進行選擇。 anujs現在只差一個組件(mention)就完全支持阿里的antd UI庫了。一共跑通346個測試, 應該是全世界最接近官方React的迷你框架...
摘要:這次更新主要是改善了對焦點的處理及的語法糖的支持優化的性能,將原方法內部用到函數與對象提到全局上來,這就比官方的對象池技術更能提升性能。 anu1.2.1這次更新主要是改善了對焦點的處理及react16.2的Fragment語法糖的支持 優化fiberizeChildren的性能,將原方法內部用到函數與對象提到全局上來,這就比官方的對象池技術更能提升性能。 修復受控組件在textar...
摘要:本版本主要是對的組件進行最后一次修復工作,除了組件,都支持了。其次它是市場上唯一支持特征的庫。明年也會搞一個狀態庫,對異步渲染友好。路由,狀態庫,等一套東西與一起配合使用。 本版本主要是對antd3的組件進行最后一次修復工作,除了mention組件,都支持了。 明年的精力就集中異步渲染與后端渲染上。anujs的體積經過幾個版本的迭代,體積有所增大24kb(沒有壓縮的情況),但還是遠遠少...
摘要:在兼容官方比以往更進一步,一共跑通套測試,其中套是官方的測試。在機制,機制,虛擬更新機制,傳遞機制,生成策略上大大重構。是有史以來最多的更新級。但工作還沒有完成,只是怕更新太多做了一次短暫的休整。 anujs1.1.2在兼容官方React比以往更進一步,一共跑通293套測試,其中179套是官方React的測試。 在ref機制,owner機制,虛擬DOM更新機制,context傳遞機制,...
閱讀 2326·2021-11-17 09:33
閱讀 852·2021-10-13 09:40
閱讀 582·2019-08-30 15:54
閱讀 788·2019-08-29 15:38
閱讀 2423·2019-08-28 18:15
閱讀 2481·2019-08-26 13:38
閱讀 1848·2019-08-26 13:36
閱讀 2137·2019-08-26 11:36