news 2026/3/1 5:14:24

Prettier 配置文件 .prettierrc.js 和 .prettierrc.json 的区别

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Prettier 配置文件 .prettierrc.js 和 .prettierrc.json 的区别

.prettierrc.js 和 .prettierrc.json的区别

.prettierrc.js.prettierrc.json都是 Prettier 的配置文件,主要区别在于格式和灵活性。


1..prettierrc.json(JSON 格式)

json

{ "printWidth": 80, "tabWidth": 2, "useTabs": false, "semi": true }
  • 优点

    • 语法严格,不易出错

    • 可被其他工具轻松解析

    • 支持 JSON Schema 验证

  • 缺点

    • 不支持注释

    • 不能使用动态配置


2..prettierrc.js(JavaScript 格式)

javascript

module.exports = { printWidth: 80, tabWidth: 2, useTabs: false, semi: true, // 可以添加注释 overrides: [ { files: "*.md", options: { printWidth: 60 } } ] }
  • 优点

    • 支持注释,方便解释配置

    • 支持动态配置(条件逻辑、函数等)

    • 支持 ES modulesexport default

    • ✅ 可以引用环境变量或其他配置

  • 缺点

    • 需要 Node.js 环境来解析

    • 可能执行恶意代码(安全性考虑)


主要差异对比

特性.prettierrc.json.prettierrc.js
注释❌ 不支持✅ 支持
动态配置❌ 不支持✅ 支持
环境变量❌ 不支持✅ 支持
条件逻辑❌ 不支持✅ 支持
导入其他配置❌ 不支持✅ 支持
工具兼容性✅ 更好❌ 需要 Node.js
安全性✅ 更安全❌ 可能执行代码

使用场景建议

选择.prettierrc.json当:

  • 配置简单,不需要注释

  • 希望配置文件能被多种工具读取

  • 注重安全性和稳定性

  • 项目不依赖 Node.js 环境


选择.prettierrc.js当:

  • 配置复杂,需要注释说明

  • 需要条件配置(不同环境不同格式)

  • 需要动态生成配置

  • 想继承或合并其他配置

  • 项目本身就是 Node.js 项目


示例:.prettierrc.js 的高级用法

javascript

// 根据环境变量调整配置 const isProduction = process.env.NODE_ENV === 'production'; module.exports = { printWidth: isProduction ? 80 : 100, // 根据文件类型覆盖配置 overrides: [ { files: '*.test.js', options: { printWidth: 120 } } ], // 从其他文件导入配置 ...require('./shared-prettier-config'), // 使用函数生成配置 trailingComma: (() => { // 复杂的逻辑判断 return 'es5'; })() };

其他格式选项

Prettier 还支持:

  • .prettierrc.yaml/.prettierrc.yml- YAML 格式,支持注释

  • prettier.config.js- 另一种 JS 配置文件名

  • package.json中的prettier字段


总结推荐

  • 大多数项目:.prettierrc.json(简单直观)

  • 复杂项目/团队项目:.prettierrc.js(注释和灵活性更重要)

  • 个人项目:按喜好选择,JS 格式更灵活

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/21 8:14:54

ComfyUI BrushNet终极入门指南:5分钟搞定AI图像修复

ComfyUI BrushNet终极入门指南:5分钟搞定AI图像修复 【免费下载链接】ComfyUI-BrushNet ComfyUI BrushNet nodes 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-BrushNet ComfyUI BrushNet是一款强大的AI图像修复和编辑插件,能够实现精准…

作者头像 李华
网站建设 2026/2/28 4:48:47

Tomli 全面教程:常用 API 串联与实战指南

大家好,我是jobleap.cn的小九。 Tomli 是 Python 生态中轻量、合规的 TOML 解析库,完全遵循 TOML 1.0.0 规范,仅专注于 TOML 数据的解析(写入需搭配 tomli-w),支持 Python 3.7,纯 Python 实现且…

作者头像 李华
网站建设 2026/2/13 16:05:51

企业项目中如何处理Vue的非props属性警告

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 模拟一个电商网站项目,其中商品卡片组件(ProductCard)意外接收了class等非props属性。展示:1) 问题重现场景 2) 控制台警告截图 3) 使用inheritAttrs和$attr…

作者头像 李华
网站建设 2026/2/26 21:13:31

Pyomo数学建模工具:从理论到实践的完整指南

Pyomo数学建模工具:从理论到实践的完整指南 【免费下载链接】pyomo An object-oriented algebraic modeling language in Python for structured optimization problems. 项目地址: https://gitcode.com/gh_mirrors/py/pyomo 在当今数据驱动的世界中&#xf…

作者头像 李华
网站建设 2026/2/24 22:48:53

Cocos粒子系统完全指南:轻松打造惊艳游戏特效

Cocos粒子系统完全指南:轻松打造惊艳游戏特效 【免费下载链接】cocos-engine Cocos simplifies game creation and distribution with Cocos Creator, a free, open-source, cross-platform game engine. Empowering millions of developers to create high-perform…

作者头像 李华