微信小程序配置prettier+eslint

        虽然微信开发者工具是基于vscode魔改的.但是由于版本过低,导致很多插件也用不上新版本.所以在微信开发者工具限制的版本下使用的prettier,eslint也是有版本要求.

        本文主要就是记录一下需要的版本号

1.微信开发者工具安装插件

2.package.json中添加以下依赖及安装依赖

  "devDependencies": {"@babel/core": "^7.16.7","@babel/eslint-parser": "^7.16.5","eslint": "^7.28.0","eslint-config-airbnb-base": "15.0.0","eslint-config-prettier": "^9.1.0","eslint-plugin-import": "^2.29.1","eslint-plugin-node": "^11.1.0","eslint-plugin-prettier": "^4.1.3","eslint-plugin-promise": "^6.2.0","prettier": "^2.5.1"}

安装依赖 npm install 就不详细说明.

3.根目录下创建.eslintrc,.prettierrc

.eslintrc.js

module.exports = {root: true,env: {es6: true,browser: true,node: true,},extends: ['airbnb-base', 'plugin:import/recommended', 'plugin:import/errors', 'plugin:import/warnings', 'prettier'],plugins: ['import', 'prettier'],parser: '@babel/eslint-parser',parserOptions: {requireConfigFile: false,ecmaVersion: 2018,sourceType: 'module',ecmaFeatures: {// lambda表达式arrowFunctions: true,// 解构赋值destructuring: true,// classclasses: true,},},globals: {wx: true,App: true,Page: true,getCurrentPages: true,getApp: true,Component: true,requirePlugin: true,requireMiniProgram: true,},rules: {'prettier/prettier': 'warn','no-undef': 'off','camelcase': ['warn', { ignoreDestructuring: true }],'class-name-casing': 'off','no-console': ['warn', { allow: ['warn', 'error'] }],'no-debugger': 'error','no-unused-expressions': ['error', { allowShortCircuit: true, allowTernary: true }],'no-empty-interface': 'off','no-use-before-define': ['error', { functions: false }],'no-useless-constructor': 'error','prefer-const': 'error','prefer-destructuring': ['error',{AssignmentExpression: {array: false,object: false,},VariableDeclarator: {array: false,object: true,},},{enforceForRenamedProperties: false,},],'no-const-assign': 'error','no-new-object': 'error','no-prototype-builtins': 'error','no-array-constructor': 'error','array-callback-return': 'warn','prefer-template': 'error','no-useless-escape': 'error','wrap-iife': ['error', 'outside'],'space-before-function-paren': ['warn',{anonymous: 'always',named: 'never',asyncArrow: 'always',},],'no-param-reassign': ['warn',{props: true,ignorePropertyModificationsFor: ['acc', // for reduce accumulators'accumulator', // for reduce accumulators'e', // for e.returnvalue'ctx', // for Koa routing'req', // for Express requests'request', // for Express requests'res', // for Express responses'response', // for Express responses'$scope', // for Angular 1 scopes'staticContext', // for ReactRouter context'state', // for Vuex],},],'no-confusing-arrow': 'warn','no-dupe-class-members': 'error','no-iterator': 'warn','dot-notation': 'warn','one-var': ['warn', 'never'],'no-multi-assign': 'error','no-unused-vars': ['warn',{args: 'after-used',ignoreRestSiblings: true,argsIgnorePattern: '^_.+',varsIgnorePattern: '^_.+',},],eqeqeq: ['warn', 'always'],'no-case-declarations': 'error','no-nested-ternary': 'warn','no-unneeded-ternary': 'warn','no-mixed-operators': ['error',{groups: [['%', '**'],['%', '+'],['%', '-'],['%', '*'],['%', '/'],['&', '|', '<<', '>>', '>>>'],['==', '!=', '===', '!=='],['&&', '||'],],allowSamePrecedence: false,},],'no-else-return': ['warn',{allowElseIf: false,},],'no-new-wrappers': 'warn',indent: ['warn',2,{SwitchCase: 1,VariableDeclarator: 1,outerIIFEBody: 1,FunctionDeclaration: {parameters: 1,body: 1,},FunctionExpression: {parameters: 1,body: 1,},CallExpression: {arguments: 1,},ArrayExpression: 1,ObjectExpression: 1,ImportDeclaration: 1,flatTernaryExpressions: false,ignoreComments: false,},],'linebreak-style': ['warn', 'unix'],'import/extensions': 'off','import/no-unresolved': 'off','no-plusplus': 'off',},
}

.prettierrc.yml

这里用的yml格式,用js格式一样可以,需要修改一下内容格式

# 一行最多 100 字符
printWidth: 120
# 使用 2 个空格缩进
tabWidth: 2
# 不使用缩进符,而使用空格
useTabs: false
# 行尾需要分号
semi: false
# 使用单引号
singleQuote: true
# 对象的 key 仅在必要时用引号
quoteProps: as-needed
# jsx 不使用单引号,而使用双引号
jsxSingleQuote: false
# 末尾需要逗号
trailingComma: all
# 大括号内的首尾需要空格
bracketSpacing: true
# jsx 标签的反尖括号需要换行
jsxBracketSameLine: false
# 箭头函数,只有一个参数的时候,不需要括号
arrowParens: always
# 每个文件格式化的范围是文件的全部内容
rangeStart: 0
# 不需要写文件开头的 @prettier
requirePragma: false
# 不需要自动在文件开头插入 @prettier
insertPragma: false
# 使用默认的折行标准
proseWrap: preserve
# 根据显示样式决定 html 要不要折行
htmlWhitespaceSensitivity: css
# 换行符使用 lf
endOfLine: lf
# 后缀文件名特有规则
overrides:- files: '*.{wxss,scss}'options:parser: scss- files: '*.json,.*rc'options:parser: json- files: '*.{wxml,html}'options:parser: htmlhtmlWhitespaceSensitivity: strict- files: '*.wxs'options:parser: babel
# 是否格式化一些文件中被嵌入的代码片段的风格,如果插件可以识别。
embeddedLanguageFormatting: auto
# 在Html,Vue,JSX中是否强制每条属性占用一行。
singleAttributePerLine: false

4.微信开发工具设置prettire支持的文件格式

打开setting.json

添加或修改以下内容

    "prettier.documentSelectors": ["**/*.wxml ","**/*.wxss"," **/*.wxs"],"[wxml]": {"editor.defaultFormatter": "esbenp.prettier-vscode"},"[scss]": {"editor.defaultFormatter": "esbenp.prettier-vscode"},"[html]": {"editor.defaultFormatter": "esbenp.prettier-vscode"},"[css]": {"editor.defaultFormatter": "esbenp.prettier-vscode"},"[json]": {"editor.defaultFormatter": "esbenp.prettier-vscode"},"[javascript]": {"editor.defaultFormatter": "esbenp.prettier-vscode"},

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/54802.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JVM(HotSpot):方法区(Method Area)

文章目录 一、内存结构图二、方法区定义三、内存溢出问题四、常量池与运行时常量池 一、内存结构图 1.6 方法区详细结构图 1.8方法区详细结构图 1.8后&#xff0c;方法区是JVM内存的一个逻辑结构&#xff0c;真实内存用的本地物理内存。 且字符串常量池从常量池中移入堆中。 …

云服务器连接不上是什么原因引起的?

云服务器连接不上是什么原因引起的&#xff1f;云服务器连接不上是一个常见的问题&#xff0c;常见的原因有网络连接、账户权限、安全组设置、服务器状态、端口占用、远程登录未开启、云服务器已关闭或到期、防护软件限制、DNS劫持、资源负载过高。以下是一些主要原因及解决方法…

微信小程序 - 最新详细安装使用 Vant weapp UI 框架环境搭建详细教程

前言 自从 2024 年开始,小程序做了很多改变和升级, 导致网上很多搭建教程文章的教程失效了,本文来做最新的教程。 第一步 为了更贴合新手,我这里创建了一个纯净无任何业务代码的小程序项目。

AI语音工具——Fish Speech:使用简单,可训练专属语音模型!

1. 引言 随着人工智能技术的迅速发展&#xff0c;AI语音合成与识别技术在智能助手、虚拟主播、自动化客服等领域展现出巨大的潜力。今天&#xff0c;专属定制化语音模型不再是大公司的专利&#xff0c;Fish Speech让普通用户也能轻松训练自己的语音模型。 Fish Speech 是一款…

SpringBoot-全局处理异常,时间格式,跨域,拦截器,监听器

1.全局异常处理 使用ControllerAdvice与ExceptionHandler注解 /*** 全局异常处理程序** author * date */ ControllerAdvice ResponseBody public class GlobalExceptionHandler {ExceptionHandler(Exception.class)public JsonResult handleException(Exception e) {e.print…

Wireshark学习使用记录

wireshark 是一个非常好用的抓包工具&#xff0c;使用 wireshark 工具抓包分析&#xff0c;是学习网络编程必不可少的一项技能。 原理 Wireshark使用的环境大致分为两种:一种是电脑直连互联网的单机环境&#xff0c;另外一种就是应用比较多的互联网环境&#xff0c;也就是连接…

Windows下安装Neo4j流程

Neo4j简介 Neo4j 是一个基于图形结构的 NoSQL 数据库&#xff0c;专门用于存储和管理图数据。与传统的关系型数据库不同&#xff0c;Neo4j 使用 图&#xff08;graph&#xff09;的形式来表示数据&#xff0c;其中数据点&#xff08;称为 节点&#xff09;通过 边&#xff08;…

检测死锁的机制

PostgreSQL&#xff08;PG&#xff09;检测死锁的机制主要基于等待图&#xff08;WFG, wait-for graph&#xff09;和超时设置。以下是详细的死锁检测过程&#xff1a; 等待图构建&#xff1a;当一个事务在尝试获取资源时&#xff0c;如果未能立即获得所需的锁&#xff0c;并且…

使用lodash库实现防抖和节流

在 JavaScript 中&#xff0c;lodash 是一个非常流行的实用工具库&#xff0c;提供了许多常用的函数&#xff0c;其中就包括防抖和节流的实现。lodash 提供的 debounce 和 throttle 函数可以让我们更方便地实现这两种功能。 1. 使用 lodash 的 debounce&#xff08;防抖&#…

【6】AT32F437 OpenHarmony轻量系统移植教程(3)

开源地址&#xff1a;https://gitee.com/AT32437_OpenHarmony 学习本文档的意义 1.学习移植OpenHarmony轻量系统到AT32全系列mcu上&#xff0c;本文档移植的具体型号为AT32F437ZMT7 2.学习OpenHarmony轻量系统开发 6.target_config.h文件适配 在//kernel/liteos_m/kernel/…

秋招喜来,分享一份最新的面经

&#x1f4bc;岗位职责&#xff1a; 负责后端服务的开发与维护&#xff1b;技术预研和技术难点攻关&#xff0c;保障系统可用性、稳定性、和可扩展性&#xff1b;持续优化系统架构设计&#xff0c;提出问题解决方案。 &#x1f4cb;任职要求&#xff1a; 计算机或相关专业&a…

分拆逆势上会,兴福电子部分专利来自母公司,独立性被拷问

作者&#xff1a;Cindy 来源&#xff1a;IPO魔女 公司拟募集资金12.10亿元&#xff0c;保荐机构为天风证券。兴福电子2023年5月就提交了上市申请&#xff0c;期间经历了2轮问询&#xff0c;一年多时间就开启上会。 然而值得注意的是&#xff0c;兴福电子属于分拆上市&#xff…

亚马逊IP关联揭秘:发生ip关联如何处理

在亚马逊这一全球领先的电商平台上&#xff0c;IP关联是一个不可忽视的问题&#xff0c;尤其是对于多账号运营的卖家而言。本文将深入解析亚马逊IP关联的含义、影响以及应对策略&#xff0c;帮助卖家更好地理解和应对这一问题。 什么是亚马逊IP关联&#xff1f; 亚马逊IP关联…

Java高级Day51-apacheDBUtils

136.ApDBUtils 基本介绍 commons-dbutils 是 Apache 组织提供的一个开源JDBC工具类库&#xff0c;它是对JJDBC的封装&#xff0c;使用dbutils能极大简化jdbc编码的工作量 QueryRunner类&#xff1a;该类封装了SQL的执行&#xff0c;是线程安全的。可以实现增删改查和批处理 …

【最新华为OD机试E卷-支持在线评测】字符串变换最小字符串(100分)多语言题解-(Python/C/JavaScript/Java/Cpp)

🍭 大家好这里是春秋招笔试突围 ,一枚热爱算法的程序员 💻 ACM金牌🏅️团队 | 大厂实习经历 | 多年算法竞赛经历 ✨ 本系列打算持续跟新华为OD-E/D卷的多语言AC题解 🧩 大部分包含 Python / C / Javascript / Java / Cpp 多语言代码 👏 感谢大家的订阅➕ 和 喜欢�…

MySQL练手题--日期连续类型(困难)

一、准备工作 Create table If Not Exists Failed (fail_date date); Create table If Not Exists Succeeded (success_date date); Truncate table Failed; insert into Failed (fail_date) values (2018-12-28); insert into Failed (fail_date) values (2018-12-29); inser…

map的使用

pair类型介绍 map底层的红⿊树节点中的数据&#xff0c;使⽤pair<Key, T>存储键值对数据 typedef pair<const Key, T> value_type; template <class T1, class T2> struct pair {typedef T1 first_type;typedef T2 second_type;T1 first;T2 second;pair() : …

Unity的Text组件中实现输入内容的渐变色效果

要在Unity的Text组件中实现输入内容的渐变色效果&#xff0c;默认的Text组件不直接支持渐变色。但是&#xff0c;你可以通过以下几种方式实现&#xff1a; ### 1. **使用Shader**来实现渐变效果 通过自定义Shader为Text组件创建一个渐变效果。这是一个常用的做法&#xff0…

MySQL---创建数据库(基于SQLyog)

目录 0.前言 1.基本认识 1.1编码集 1.2检验规则 2.库的创建和销毁 2.1指令介绍 2.2你可能会出现的问题 3.查看数据库属性 4.创建指定数据库 5.创建表操作 0.前言 之前写过一篇这个关于表的创建和销毁的操作&#xff0c;但是当时是第一次学习&#xff0c;肯定有些地方…

初识 C 语言(一)

目录 一、 第一个 C 程序1. printf() 函数和 stdio.h 头文件2. main() 函数和 return 语句 二、类型和变量1. C 语言中的基本类型2. 变量的创建和命名规则3. 类型和变量的大小 三、printf() 函数和 scanf() 函数1. printf() 函数的使用2. 各种类型的输出格式3. scanf() 函数的使…