Сохранение вертикальных пробелов в шаблоне Vue с помощью Prettier - PullRequest
0 голосов
/ 13 ноября 2018

Я использую eslint-plugin-vue с моим проектом Vue.

У меня есть следующий файл .prettierrc:

// /.prettierrc
{
  "arrowParens": "avoid",
  "bracketSpacing": true,
  "insertPragma": false,
  "jsxBracketSameLine": false,
  "printWidth": 80,
  "proseWrap": "preserve",
  "requirePragma": false,
  "semi": false,
  "singleQuote": true,
  "tabWidth": 2,
  "trailingComma": "es5",
  "useTabs": false
}

Иследующий .eslintrc.js файл:

module.exports = {
  root: true,
  env: {
    node: true,
  },
  extends: [
    'plugin:vue/recommended',
    '@vue/prettier',
  ],
  rules: {
    'linebreak-style': ['error', 'unix'],
    'no-console': process.env.NODE_ENV === 'production' ? 'error' : 'off',
    'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off',
    'vue/max-attributes-per-line': 'off',
    'vue/html-self-closing': [
      'error',
      {
        html: {
          void: 'always',
          normal: 'always',
          component: 'always',
        },
        svg: 'always',
        math: 'always',
      },
    ],
  },
  plugins: ['vue'],
  parserOptions: {
    parser: 'babel-eslint',
  },
}

Но, к сожалению, красивее кажется, что

<template>
  <header><a href="/" class="logo"> Home </a></header>
</template>

красивее

<template>
  <header>
    <a href="/" class="logo">
      Home
    </a>
  </header>
</template>

Prettier being annoying


Как мне сказать красивее сохранить вертикальный пробел в шаблоне Vue?

Существуют ли какие-либо правила, аналогичные тем, которые я хочу?

Ответы [ 2 ]

0 голосов
/ 08 мая 2019

Ваш единственный вариант (обходной путь) использует игнорирование.

Ex Js файлы. // prettier-ignore
Ex HTML-файлы. <!-- prettier-ignore -->

https://prettier.io/docs/en/ignore.html

0 голосов
/ 13 марта 2019

Вот список правил для vue в eslint: https://vuejs.github.io/eslint-plugin-vue/rules/ Но если вы отключите правило, оно будет применено ко всему вашему коду.

Кроме того, кажется, что вы можете сказать Prettierигнорировать блок: https://prettier.io/docs/en/ignore.html#html

Кроме того, я бы сказал, что это более «читабельно», но это моя точка зрения:)

<template>
  <header>
    <a href="/" class="logo">Home</a>
  </header>
</template>
...