当前位置: 首页 > news >正文

【Vue3/Typescript】从零开始搭建H5移动端项目

一、 集成 ESLint

1.通过以下命令快速生成 ESLint 配置文件:

npx eslint --init

执行该命令后,ESLint 会通过交互式问题的方式,帮助生成配置文件eslint.config.mjs 。在此基础上,可以根据项目的需求进行一些定制化配置。

2.安装 Vue 文件解析器 vue-eslint-parser

pnpm add -D vue-eslint-parser

3.eslint.config.mjs配置

//eslint.config.mjsimport globals from "globals";
import pluginJs from "@eslint/js"; // JavaScript 规则
import pluginVue from "eslint-plugin-vue"; // Vue 规则
import pluginTypeScript from "@typescript-eslint/eslint-plugin"; // TypeScript 规则import parserVue from "vue-eslint-parser"; // Vue 解析器
import parserTypeScript from "@typescript-eslint/parser"; // TypeScript 解析器import configPrettier from "eslint-config-prettier"; // 禁用与 Prettier 冲突的规则
import pluginPrettier from "eslint-plugin-prettier"; // 运行 Prettier 规则// 解析自动导入配置
import fs from "fs";
const autoImportConfig = JSON.parse(fs.readFileSync(".eslintrc-auto-import.json", "utf-8"));/** @type {import('eslint').Linter.Config[]} */
export default [// 指定检查文件和忽略文件{files: ["**/*.{js,mjs,cjs,ts,vue}"],ignores: ["**/*.d.ts"],},// 全局配置{languageOptions: {globals: {...globals.browser,...globals.node,...autoImportConfig.globals,...{PageQuery: "readonly",PageResult: "readonly",OptionType: "readonly",ResponseData: "readonly",ExcelResult: "readonly",TagView: "readonly",AppSettings: "readonly",__APP_INFO__: "readonly",},},},plugins: { prettier: pluginPrettier },rules: {...configPrettier.rules, // 关闭与 Prettier 冲突的规则...pluginPrettier.configs.recommended.rules, // 启用 Prettier 规则"prettier/prettier": "error", // 强制 Prettier 格式化"no-unused-vars": ["error",{argsIgnorePattern: "^_", // 忽略参数名以 _ 开头的参数未使用警告varsIgnorePattern: "^[A-Z0-9_]+$", // 忽略变量名为大写字母、数字或下划线组合的未使用警告(枚举定义未使用场景)ignoreRestSiblings: true, // 忽略解构赋值中同级未使用变量的警告},],},},// JavaScript 配置pluginJs.configs.recommended,// TypeScript 配置{files: ["**/*.ts"],ignores: ["**/*.d.ts"], // 排除d.ts文件languageOptions: {parser: parserTypeScript,parserOptions: {sourceType: "module",},},plugins: { "@typescript-eslint": pluginTypeScript },rules: {...pluginTypeScript.configs.strict.rules, // TypeScript 严格规则"@typescript-eslint/no-explicit-any": "off", // 允许使用 any"@typescript-eslint/no-empty-function": "off", // 允许空函数"@typescript-eslint/no-empty-object-type": "off", // 允许空对象类型},},// Vue 配置{files: ["**/*.vue"],languageOptions: {parser: parserVue,parserOptions: {parser: parserTypeScript,sourceType: "module",},},plugins: { vue: pluginVue, "@typescript-eslint": pluginTypeScript },processor: pluginVue.processors[".vue"],rules: {...pluginVue.configs["vue3-recommended"].rules, // Vue 3 推荐规则"vue/no-v-html": "off", // 允许 v-html"vue/multi-word-component-names": "off", // 允许单个单词组件名},},
];

二、按需自动导入

1.安装

npm install unplugin-auto-import -D

2.在vite.config.ts中更改配置


import AutoImport from "unplugin-auto-import/vite";
export default defineConfig({plugins:[vue(),...AutoImport({// 自动导入 Vue 相关函数,如:ref, reactive, toRef 等imports: ["vue", "@vueuse/core", "pinia", "vue-router", "vue-i18n"],resolvers: [// 自动导入 Element Plus 相关函数,如:ElMessage, ElMessageBox... (带样式)ElementPlusResolver({importStyle: "sass",}),],eslintrc: {// 是否自动生成 eslint 规则,建议生成之后设置 falseenabled: false,// 指定自动导入函数 eslint 规则的文件filepath: "./.eslintrc-auto-import.json",globalsPropValue: true,},// 是否在 vue 模板中自动导入vueTemplate: true,// 指定自动导入函数TS类型声明文件路径 (false:关闭自动生成)dts: false,// dts: "src/typings/auto-imports.d.ts",}),]
}

三、UI框架选择

UI框架使用Vant

Vant 是一个轻量、可定制的移动端组件库,于 2017 年开源。

目前 Vant 官方提供了 Vue 2 版本、Vue 3 版本和微信小程序版本,并由社区团队维护 React 版本和支付宝小程序版本。

四、Rem 布局适配

使用 rem 单位进行适配,推荐使用以下两个工具:

postcss-pxtorem 是一款 PostCSS 插件,用于将 px 单位转化为 rem 单位
lib-flexible 用于设置 rem 基准值
1.安装postcss-pxtorem

 npm install  postcss-pxtorem  -D

2.新建postcss.config.ts

//postcss.config.ts
module.exports = {plugins: {"postcss-pxtorem": {rootValue: 37.5,//设计稿宽度%10 比如 375propList: ["*"],},},
};

五、 底部安全区适配

iPhone X 等机型底部存在底部指示条,指示条的操作区域与页面底部存在重合,容易导致用户误操作,因此我们需要针对这些机型进行安全区适配。Vant 中部分组件提供了 safe-area-inset-top 或 safe-area-inset-bottom 属性,设置该属性后,即可在对应的机型上开启适配,如下示例:

<!-- 在 head 标签中添加 meta 标签,并设置 viewport-fit=cover 值 -->
<metaname="viewport"content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, viewport-fit=cover"
/><!-- 开启顶部安全区适配 -->
<van-nav-bar safe-area-inset-top /><!-- 开启底部安全区适配 -->
<van-number-keyboard safe-area-inset-bottom />
http://www.xdnf.cn/news/1008001.html

相关文章:

  • 【二分模版------左闭右闭】
  • Vue ⑨-Pinia
  • c++ - 关于 string 的练习题
  • 《深度剖析:Java中用Stanford NLP工具包优化命名实体识别》
  • Redis哨兵机制
  • 获取Unity节点路径
  • ✅ [Dify]明道云同步内容到 Dify 知识库的最佳实践指南
  • 电梯钢带安全无盲区:电梯钢带断丝智慧监测方案让隐患“毫秒现形“
  • SpringCloud-seata集成到nacos
  • 实战二:基于网页端实现与大模型的问答交互
  • 虚拟 DOM Diff 算法详解
  • UE5场景漫游——鼠标控制旋转与第一人称漫游
  • 51la批量创建站点繁琐?悟空统计一站式高效解决方案
  • Spring Data REST技术详解与应用实践
  • HALCON第四讲->几何变换
  • SX1268低功耗sub-1g芯片支持lora和GFSK调制
  • MATLAB griddatan 函数支持的插值方法MATLAB 的 griddatan 函数主要支持以下几种插值方法
  • 关于等效偶极子的概念理解
  • QT5 隐藏控制台窗口方法2025.6.12
  • 【Java面试笔记:实战】41、Java面试核心考点!AQS原理及应用生态全解析
  • FastDFS 分布式文件系统
  • 设计一个类似支付宝或微信支付的在线支付系统
  • 【ubuntu驱动安装】安装nvidia驱动和cuda环境
  • 【洛杉矶实况】这里正在发生什么?
  • shell脚本不同执行方式的区别
  • Python 100个常用函数全面解析
  • python实现层次分析法(AHP)权重设置与稳健性检验完整解决方案
  • 如何学习VBA:3.3.4从初学到精进的方法
  • 2025虚幻游戏逆向工程解包尝试
  • 无人机避障——感知篇(Orin nx采用zed2双目相机进行Vins-Fusion定位,再通过位姿和深度图建图完成实时感知)