valid-v-if.js 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. /**
  2. * @author Toru Nagashima
  3. * @copyright 2017 Toru Nagashima. All rights reserved.
  4. * See LICENSE file in root directory for full license.
  5. */
  6. 'use strict'
  7. // ------------------------------------------------------------------------------
  8. // Requirements
  9. // ------------------------------------------------------------------------------
  10. const utils = require('../utils')
  11. // ------------------------------------------------------------------------------
  12. // Rule Definition
  13. // ------------------------------------------------------------------------------
  14. module.exports = {
  15. meta: {
  16. type: 'problem',
  17. docs: {
  18. description: 'enforce valid `v-if` directives',
  19. categories: ['vue3-essential', 'essential'],
  20. url: 'https://eslint.vuejs.org/rules/valid-v-if.html'
  21. },
  22. fixable: null,
  23. schema: []
  24. },
  25. /** @param {RuleContext} context */
  26. create(context) {
  27. return utils.defineTemplateBodyVisitor(context, {
  28. /** @param {VDirective} node */
  29. "VAttribute[directive=true][key.name.name='if']"(node) {
  30. const element = node.parent.parent
  31. if (utils.hasDirective(element, 'else')) {
  32. context.report({
  33. node,
  34. loc: node.loc,
  35. message:
  36. "'v-if' and 'v-else' directives can't exist on the same element. You may want 'v-else-if' directives."
  37. })
  38. }
  39. if (utils.hasDirective(element, 'else-if')) {
  40. context.report({
  41. node,
  42. loc: node.loc,
  43. message:
  44. "'v-if' and 'v-else-if' directives can't exist on the same element."
  45. })
  46. }
  47. if (node.key.argument) {
  48. context.report({
  49. node,
  50. loc: node.loc,
  51. message: "'v-if' directives require no argument."
  52. })
  53. }
  54. if (node.key.modifiers.length > 0) {
  55. context.report({
  56. node,
  57. loc: node.loc,
  58. message: "'v-if' directives require no modifier."
  59. })
  60. }
  61. if (!node.value || utils.isEmptyValueDirective(node, context)) {
  62. context.report({
  63. node,
  64. loc: node.loc,
  65. message: "'v-if' directives require that attribute value."
  66. })
  67. }
  68. }
  69. })
  70. }
  71. }