-
-
Notifications
You must be signed in to change notification settings - Fork 4.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
refactor: drop lodash for lib/theme #3807
Conversation
According to benchmark performed by Travis CI, this PR makes generation speed 3x slower. |
f093749
to
7928973
Compare
@@ -28,7 +27,7 @@ function Theme(ctx) { | |||
languages.push('default'); | |||
|
|||
this.i18n = new I18n({ | |||
languages: _(languages).compact().uniq().value() | |||
languages: [...new Set(languages.filter(Boolean))] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what about Array.from(new Set(languages.filter(Boolean)))
?
I wonder if value()
is needed, I can't find it in lodash doc, perhaps it's a function of languages
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
value()
is a lodash method, which is used to get value from lodash wrapped prototype chain.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I have make a benchmark at jsPerf: https://jsperf.com/lodash-uniq-vs-javascript-set/1
It seems the diffrence between Array.from
& spread syntax is negligible, at least in browser.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see.
The travis benchmark showed the spread syntax is the source of regression. I noticed you reverted the last commit; to confirm the source?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It seems the diffrence between Array.from & spread syntax is negligible, at least in browser.
Similar result in travis too. Can you try revert back to lodash just for this line? to test whether Set()
is the culprit.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
But that doesn't explain why lodash is faster in view.js
.
btw, as for the lib/theme, I think it's fine to use Set() since languages
array would only have 2 elements max, so it wouldn't (and shouldn't) make any difference.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@curbengh I have done through some investigation about performance of Object.assign
. It seems that Object.assign
will meet performance issue when facing large object. Even Node.js itself is still using the deprecated util._extend
, because it is still a lot more faster than Object.assign
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A bit more interesting... Even if I replace Object.assign with lodash.assign, the impact is still there. So maybe the problem is at Object.getPrototypeOf
..
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That seems like the last suspect now. what about return Object.assign({}, locals, locals.prototype, data, {
? (source)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@curbengh In fact I have tried local.prototype
at very beginning but it won't pass the test. The locals
here is differentwith a constructor.
4fd4a9f
to
10d8fb7
Compare
What does it do?
This PR is a part of #3753
How to test
Screenshots
Pull request tasks