【问题标题】:Can't run ng lint on my angular-cli project无法在我的 angular-cli 项目上运行 ng lint
【发布时间】:2017-02-28 07:44:21
【问题描述】:

ng -v: 1.0.0-beta.32.3

"devDependencies": {
    "@angular/compiler-cli": "2.4.4",
    "@types/jasmine": "^2.5.38",
    "@types/node": "^6.0.42",
    "codelyzer": "~2.0.0-beta.4",
    "jasmine-core": "^2.5.2",
    "jasmine-spec-reporter": "^3.2.0",
    "karma": "^1.4.1",
    "karma-cli": "^1.0.1",
    "karma-jasmine": "^1.1.0",
    "karma-phantomjs-launcher": "^1.0.2",
    "karma-remap-istanbul": "^0.6.0",
    "protractor": "^4.0.13",
    "ts-node": "~2.0.0",
    "tslint": "^4.4.2",
    "typescript": "~2.0.3"
  }

/tslint.json

{
  "rulesDirectory": [
    "node_modules/codelyzer"
  ],
  "rules": {
    "class-name": true,
    "comment-format": [
      true,
      "check-space"
    ],
    "curly": true,
    "eofline": true,
    "forin": true,
    "indent": [
      true,
      "spaces"
    ],
    "label-position": true,
    "max-line-length": [
      false,
      140
    ],
    "member-access": false,
    "member-ordering": [
      true,
      "static-before-instance"
    ],
    "no-arg": true,
    "no-bitwise": true,
    "no-console": [
      true,
      "debug",
      "info",
      "time",
      "timeEnd",
      "trace"
    ],
    "no-construct": true,
    "no-debugger": true,
    "no-duplicate-variable": true,
    "no-empty": false,
    "no-eval": true,
    "no-inferrable-types": true,
    "no-shadowed-variable": true,
    "no-string-literal": false,
    "no-switch-case-fall-through": true,
    "no-trailing-whitespace": true,
    "no-unused-expression": true,
    "no-use-before-declare": true,
    "no-var-keyword": true,
    "object-literal-sort-keys": false,
    "one-line": [
      true,
      "check-open-brace",
      "check-catch",
      "check-else",
      "check-whitespace"
    ],
    "quotemark": [
      true,
      "single"
    ],
    "radix": true,
    "semicolon": [
      "always"
    ],
    "triple-equals": [
      true,
      "allow-null-check"
    ],
    "typedef-whitespace": [
      true,
      {
        "call-signature": "nospace",
        "index-signature": "nospace",
        "parameter": "nospace",
        "property-declaration": "nospace",
        "variable-declaration": "nospace"
      }
    ],
    "variable-name": false,
    "whitespace": [
      true,
      "check-branch",
      "check-decl",
      "check-operator",
      "check-separator",
      "check-type"
    ],

    "use-input-property-decorator": true,
    "use-output-property-decorator": true,
    "use-host-property-decorator": true,
    "no-input-rename": true,
    "no-output-rename": true,
    "use-life-cycle-interface": true,
    "use-pipe-transform-interface": true,
    "component-class-suffix": true,
    "directive-class-suffix": true
  }
}

/src/tsconfig.json

{
  "compilerOptions": {
    "baseUrl": "",
    "declaration": false,
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "lib": ["es6", "dom", "es2017.object"],
    "mapRoot": "./",
    "module": "es6",
    "moduleResolution": "node",
    "noUnusedParameters": false,
    "noUnusedLocals": true,
    "outDir": "../dist/out-tsc",
    "sourceMap": true,
    "target": "es5",
    "typeRoots": [
      "../node_modules/@types"
    ],
    "paths": {
      "angular2/*": [
        "@angular/*"
      ]
    }
  }
}

.angular-cli.json

{
  "project": {
    "version": "1.0.0-beta.32.3",
    "name": "myapp"
  },
  "apps": [
    {
      "root": "src",
      "outDir": "dist",
      "assets": [
        "assets",
        "favicon.ico"
      ],
      "index": "index.html",
      "main": "main.ts",
      "test": "test.ts",
      "tsconfig": "tsconfig.json",
      "prefix": "app",
      "mobile": false,
      "styles": [
        "../node_modules/normalize-css/normalize.css",
        "styles.styl"
      ],
      "scripts": [],
      "environmentSource": "environments/environment.ts",
      "environments": {
        "dev": "environments/environment.ts",
        "prod": "environments/environment.prod.ts"
      }
    }
  ],
  "addons": [],
  "packages": [],
  "e2e": {
    "protractor": {
      "config": "./protractor.conf.js"
    }
  },
  "test": {
    "karma": {
      "config": "./karma.conf.js"
    }
  },
  "defaults": {
    "styleExt": "styl",
    "prefixInterfaces": false,
    "inline": {
      "style": false,
      "template": false
    },
    "spec": {
      "class": false,
      "component": true,
      "directive": true,
      "module": false,
      "pipe": true,
      "service": true
    }
  }
}

当我运行ng lint 时,我收到黄色粉笔错误No lint config(s) found. If this is not intended, run "ng update".(这听起来很奇怪,因为从 beta.32.3 开始,ng update 命令已被删除)

配置可能出了什么问题?

【问题讨论】:

  • 您可以添加您的.angular-cli.json 文件吗?您最近是否升级到另一个 cli 版本?为什么你的 package.json 的 devDependencies 中没有 @angular/cli?
  • @Dinistro 它在主部门,我现在把它移到了开发部门。是的,项目中有一个yarn upgrade,可能造成了一些混乱。
  • @ParthGhiya 好点。我很高兴 Brocco 和公司将很快提供有关 angular-cli.json 文件的文档!
  • @nuton.. 是的!!

标签: angular angular-cli lint


【解决方案1】:

您忘记应用此处提到的一些重大更改:https://github.com/angular/angular-cli/blob/master/CHANGELOG.md

要解决掉毛问题,请将以下内容添加到 .angular-cli.json 文件中。

"lint": [
   {
     "files": "src/**/*.ts",
     "project": "src/tsconfig.json"
   },
   {
     "files": "e2e/**/*.ts",
     "project": "e2e/tsconfig.json"
   }
],

也可能是,您的 cli 的全局版本和本地版本不同。请运行以下命令以确保两者具有相同的版本(我会直接升级到 rc.0):

npm i -g @angular/cli@1.0.0-rc.0

rm -rf node_modules/ 

npm i -D @angular/cli@1.0.0-rc.0
npm i 

在此之后,您应该在全球和本地拥有最新版本

【讨论】:

  • 我之前有过这种情况,但后来我收到一条消息,说我使用的是本地版本,这是一个非常好的策略。因此,除非他们改变策略,否则我认为这不会成为问题。不过,谢谢你提出来。
猜你喜欢
  • 2018-07-08
  • 2017-03-15
  • 1970-01-01
  • 2019-02-08
  • 2021-12-21
  • 1970-01-01
  • 1970-01-01
  • 2020-03-16
  • 2020-07-26
相关资源
最近更新 更多