Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
Test UseRef
Go to the benchmark
Embed
Embed Benchmark Result
Run details:
User agent:
Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:127.0) Gecko/20100101 Firefox/127.0
Browser:
Firefox 127
Operating system:
Mac OS X 10.15
Device Platform:
Desktop
Date tested:
one year ago
Test name
Executions per second
No useMemo
10851.5 Ops/sec
useMemo
9578.8 Ops/sec
useRef
11406.8 Ops/sec
HTML Preparation code:
<div id="root"></div> <script src="https://unpkg.com/react@16/umd/react.development.js"></script> <script src="https://unpkg.com/react-dom@16/umd/react-dom.development.js"></script> <script src="https://cdn.jsdelivr.net/npm/lodash@4.17.15/lodash.min.js"></script>
Script Preparation code:
function ChildComponent(props) { return React.createElement("div", props); } const a = { a: "hello", b: "world" } function UseMemoAlone(props) { const handler = React.useMemo(() => { return { ...a, c: "!!" } }, []); return React.createElement(ChildComponent, { className: handler.toString() }); } function NoMemo(props) { const handler = { ...a, c: "!!" }; return React.createElement(ChildComponent, { className: handler.toString() }); } function UseRefAlone(props) { const handler = React.useRef({ ...a, c: "!!" }); return React.createElement(ChildComponent, { className: handler.toString() }); } var propCases = [{ handler: function() { return Math.random(); }, wait: 100 }, { handler: function() { return Math.random(); }, wait: 200 }, { handler: function() { return Math.random(); }, wait: 300 }]; propCases.push(propCases[1]);
Tests:
No useMemo
propCases.forEach((props) => { ReactDOM.render(React.createElement(NoMemo, props, null), root); });
useMemo
propCases.forEach((props) => { ReactDOM.render(React.createElement(UseMemoAlone, props, null), root); });
useRef
propCases.forEach((props) => { ReactDOM.render(React.createElement(UseRefAlone, props, null), root); });