- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 695
Description
https://eslint.vuejs.org/rules/v-on-function-call.html#vue-v-on-function-call
I want to have a new option for v-on-function-call to enforce a 3rd way of writing that is not yet enforcable. My reasoning is very sound I believe bet let me elaborate:
Please describe what the rule should do:
There are 3 ways in Vue to pass an event listener in HTML:
<button @click="fn" />
<button @click="fn()" />
<button @click="() => fn()" />    To me there are clear PROs for using the last way and only CONs for using the first two. This is why I want to enforce this style with a new rule.
Here is my reasoning:
<button @click="fn" />- CON: it's unclear to see what payload comes out of the event and what payload goes into the fnif any.
- CON: sometimes fndoesn't accept a payload, but will still receive one because of this way of writing
- CON: sometimes fnis used somewhere else with a payload, but passed here as well, but it will end up receivingPointerEvent | MouseEventimplicitly which can cause bugs that are hard to find because it's implicit
- CON: a lot of VSCode themes color this the same color as a prop, so it becomes hard to see that it's a function:
  
<button @click="fn()" />- CON: this just looks like a function is being passed and immidiately executed...
- CON: if this were a prop, then this way of writing would immidiately execute the function. So it's really confusing
<button @click="() => fn()" />    - PRO: it doesn't look like a function is being immidiately executed
- PRO: it's clear what payload comes out of the click event and what payload goes into the fn, if any
What category should the rule belong to?
[x] Enforces code style (layout)
[ ] Warns about a potential error (problem)
[ ] Suggests an alternate way of doing something (suggestion)
[ ] Other (please specify:)
Provide 2-3 code examples that this rule should warn about:
I believe the explanation above is clear enough but let me know if it doesn't