第13章 工程化实践_第13章 工程化实践课
off999 2025-09-24 02:32 57 浏览 0 评论
13.1 ESLint + Prettier代码规范
统一代码风格配置
// .eslintrc.js
module.exports = {
root: true,
env: {
node: true,
es6: true
},
extends: [
'plugin:vue/vue3-recommended',
'@vue/standard'
],
rules: {
'vue/multi-word-component-names': 'off',
'no-console': process.env.NODE_ENV === 'production' ? 'warn' : 'off'
}
}
// .prettierrc
{
"semi": false,
"singleQuote": true,
"trailingComma": "none",
"printWidth": 100
}自动化修复与提交检查
# 安装Husky + lint-staged
npm install husky lint-staged --save-dev
# 配置package.json
{
"scripts": {
"prepare": "husky install",
"lint": "eslint --ext .js,.vue src",
"format": "prettier --write src/**/*.{js,vue}"
},
"lint-staged": {
"*.{js,vue}": ["eslint --fix", "prettier --write"]
}
}
# 添加Git钩子
npx husky add .husky/pre-commit "npx lint-staged"13.2 自动化测试(Jest + Puppeteer)
单元测试配置(Jest)
// jest.config.js
module.exports = {
preset: '@vue/cli-plugin-unit-jest',
testMatch: ['**/tests/unit/**/*.spec.js'],
transform: {
'^.+\\.vue#39;: 'vue-jest'
},
collectCoverage: true,
coverageDirectory: 'coverage'
}
// 示例测试用例(测试Vue组件)
import { mount } from '@vue/test-utils'
import Button from '@/components/Button.vue'
test('按钮点击事件触发', async () => {
const wrapper = mount(Button)
await wrapper.trigger('click')
expect(wrapper.emitted('click')).toBeTruthy()
})端到端测试(Puppeteer)
// tests/e2e/home.spec.js
const puppeteer = require('puppeteer')
describe('首页测试', () => {
let browser, page
beforeAll(async () => {
browser = await puppeteer.launch({ headless: true })
page = await browser.newPage()
await page.goto('http://localhost:8080')
})
afterAll(async () => {
await browser.close()
})
test('页面标题正确', async () => {
const title = await page.title()
expect(title).toBe('首页 - 我的应用')
})
})多平台测试策略
13.3 CI/CD持续集成方案
GitHub Actions配置
# .github/workflows/build.yml
name: UniApp CI/CD
on:
push:
branches: [ main ]
pull_request:
branches: [ main ]
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
platform: [mp-weixin, h5, app-plus]
steps:
- uses: actions/checkout@v2
- name: Setup Node.js
uses: actions/setup-node@v2
with:
node-version: '16'
- name: Install Dependencies
run: npm ci
- name: Build for Platform
run: npm run build:${{ matrix.platform }}
env:
VUE_APP_API: ${{ secrets.API_BASE }}
- name: Upload Artifact
uses: actions/upload-artifact@v2
with:
name: ${{ matrix.platform }}-build
path: dist/${{ matrix.platform }}Docker多阶段构建
# 构建阶段
FROM node:16 AS builder
WORKDIR /app
COPY package*.json ./
RUN npm ci
COPY . .
RUN npm run build:h5
# 生产阶段
FROM nginx:alpine
COPY --from=builder /app/dist/h5 /usr/share/nginx/html
COPY nginx.conf /etc/nginx/conf.d/default.conf
EXPOSE 80
CMD ["nginx", "-g", "daemon off;"]13.4 错误监控与日志分析体系
Sentry集成方案
// main.js
import * as Sentry from '@sentry/vue'
import { Integrations } from '@sentry/tracing'
if (process.env.NODE_ENV === 'production') {
Sentry.init({
Vue,
dsn: 'https://your-dsn@sentry.io/12345',
integrations: [new Integrations.BrowserTracing()],
tracesSampleRate: 0.2
})
}
// 捕获未处理异常
uni.onUnhandledRejection(error => {
Sentry.captureException(error)
})日志分级与收集
// utils/logger.js
const logLevels = ['debug', 'info', 'warn', 'error']
export const logger = {
debug(msg) {
if (process.env.NODE_ENV !== 'production') {
console.log(`[DEBUG] ${msg}`)
}
this._sendLog('debug', msg)
},
error(msg) {
console.error(msg)
this._sendLog('error', msg)
Sentry.captureException(msg)
},
_sendLog(level, msg) {
uni.request({
url: '/api/logs',
method: 'POST',
data: { level, message: msg }
})
}
}实时监控看板
指标 | 工具 | 功能 |
错误发生率 | Sentry | 实时错误追踪与聚合 |
性能指标 | Google Analytics | 页面加载时间、交互延迟 |
用户行为 | Hotjar | 会话回放与热力图分析 |
服务健康状态 | Grafana | 接口响应时间监控 |
本章核心技术总结
- 代码规范:通过自动化工具实现代码风格统一,提升团队协作效率
- 测试覆盖:单元测试覆盖率可达80%+,端到端测试覆盖核心流程
- 持续交付:构建部署时间从30分钟缩短至5分钟以内
- 监控体系:生产环境错误响应时间低于1分钟
相关推荐
- 360手机助手老旧版本大全(360手机助手 老版本)
-
在设置里面找到历史记录就可能查看360手机助手·换机神器是安卓系统的换机软件,因为苹果的换机软件是爱思。1、打开360手机卫士,登陆账号,点击账号。2、进入个人中心,点击账户安全,在密保工具中,点击解...
- 系统应用工程师(系统工程的应用)
-
信息软件系统工程师有前途,毕业以后可以从事软件开发,软件系统的维护,运营等等,和计算机有关的工作内容,因为计算机专业可以说是一个非常热门的专业,很多的大型企业公司基本上都是以计算机研发为主的,薪资福利...
- qq恢复系统常见问题(qq恢复系统常见问题及答案)
-
QQ好友恢复系统一直显示服务器频繁有可能是系统的问题,你的qq重新更新一下,或者你卸载了重新下载一下就有可能好了。您好,很高兴为您解答:您可以试试清空下IE内存,然后关掉不必要的程序,尽量在电脑运...
- win10自带的office不见了(win10自带的office在哪个文件夹)
-
win10系统的office在电脑硬盘office的安装目录里,具体打开安装目录的操作如下:1、首先我们右键点击word,打开方式,选择默认程序打开。2、在默认框打钩,点击【浏览】。3、打开你安装of...
- w10系统我的电脑在哪里(windows10 我的电脑在哪)
-
首先,打开Windows10系统,可以看到当前桌面上没有“我的电脑”。二、然后,在桌面上鼠标右键都加空白处,在右键菜单中选择“个性化”,点击打开。三、然后,在窗口中左侧选择“更改桌面图标”,点击打开。...
- 2500电脑组装最强配置(2500左右组装电脑主机配置清单)
-
两千五百元组装电脑,但配置只能是一般。台式机分为主机和显示器两个主体,按这个价格,显示器只能配置一般的,大约两百多元价格,其余都用来组装主机,主机包含机箱,电源,排风扇,电脑主板及内存,电脑处理器,声...
-
- 小米手机定时关机怎么设置(如何让小米手机定时关机)
-
1、从设置菜单中找到电池与性能选项。 2、选择电池版块,点击定时开关机。 3、将定时开机右边的按钮开...
-
2025-12-28 02:51 off999
- 磁盘删除的文件怎么恢复(磁盘误删怎么恢复)
-
可以恢复,因为删除文件时,其实只是把表头删除了,后面的数据并没有删除,直到下一次进行写磁盘操作需要占用节点所在位置时,才会把相应的数据覆盖掉。所以,就算你误删了文件之后又进行了其他写磁盘操作,只要没有...
-
- qq自动回复内容古风(qq自动回复古文)
-
1、抽剑相助,搭救无辜,却引来杀身之祸。那女子故作柔弱,假装爱慕,只为那本剑谱。2、只缘感君一回顾,使我思君朝与暮。3、相知相惜若可谓缘,不负韶华年。4、看那天地日月,恒静无言;青山长河,世代绵延;就像在我心中,你从未离去,也从未改变。5、...
-
2025-12-28 01:51 off999
- 惠普电脑bios设置u盘启动(惠普 bios u盘启动)
-
惠普电脑bios设置u盘启动:1、插上制作好的u启动启动盘的u盘并启动电脑,在进入开机画面的时候按“f2”进入bios界面;2、进入bios界面之后切换到“boot”,准备设置u盘启动;3、这里在键盘...
- win7优化开机启动项(windows10启动项优化)
-
开机出现错误0xc0000017无法开机错误的解决办法。1、就是system文件丢失了。2、如果想来恢复正常,需要有U盘或者光盘的pe系统,在pe下修复。3、本身C:\Windows\System32...
- 默认浏览器怎么改(软件默认浏览器怎么改)
-
在浏览器中设置默认浏览器的方法略有不同,以下是在常见的几个浏览器中设置默认浏览器的方法:1.在Windows10中设置Edge浏览器为默认浏览器: a.打开...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
