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

DeepSeek 助力 Vue 开发:打造丝滑的表单验证(Form Validation)

前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕

共同探索软件研发!敬请关注【宝码香车】
关注描述

csdngif标识

目录

  • DeepSeek 助力 Vue 开发:打造丝滑的表单验证(Form Validation)
    • 📚前言
    • 📚页面效果
    • 📚指令输入
      • 组件属性定义
        • 1. 表单数据绑定相关
        • 2. 验证规则相关
        • 3. 样式和布局相关
        • 4. 其他
      • 组件事件定义
        • 1. 验证相关
        • 2. 表单提交相关
        • 3. 字段值变化相关
      • 其他可能实现的功能
        • 1. 验证规则扩展
        • 2. 错误提示处理
        • 3. 可访问性
        • 4. 性能优化
        • 5. 组件嵌套
    • 📚think
      • 📘组件代码
    • 📚代码测试
    • 📚测试代码正常跑通,附其他基本代码
      • 📘编写路由 src\router\index.js
      • 📘编写展示入口 src\App.vue
    • 📚页面效果
    • 📚相关文章


📚📗📕📘📖🕮💡📝🗂️✍️🛠️💻🚀🎉🏗️🌐🖼️🔗📊👉🔖⚠️🌟🔐⬇️·正文开始⬇️·🎥😊🎓📩😺🌈🤝🤖📜📋🔍✅🧰❓📄📢📈 🙋0️⃣1️⃣2️⃣3️⃣4️⃣5️⃣6️⃣7️⃣8️⃣9️⃣🔟🆗*️⃣#️⃣

DeepSeek 助力 Vue 开发:打造丝滑的表单验证(Form Validation)

📚前言

DeepSeek 在电信、汽车等行业也展现出了广阔的应用前景。

在电信行业,三大基础电信企业均全面接入 DeepSeek 开源大模型,实现在多场景、多产品中应用,针对热门的 DeepSeek-R1 模型提供专属算力方案和配套环境,助力国产大模型性能释放。电信企业利用 DeepSeek 的强大能力,结合自身在 5G、云平台、大数据等方面的优势,拓展 AI 应用场景,丰富 AI 应用供给。在智能客服方面,DeepSeek 能够快速准确地回答用户的问题,提供个性化的服务建议,提升用户满意度;在网络优化方面,通过对大量网络数据的分析,DeepSeek 可以帮助电信企业优化网络布局,提高网络性能,降低运营成本。

📚页面效果

页面效果

📚指令输入

已经创建好了一个基于Vue3的组合式API的项目(Composition API),并能正常运行起来,请帮我用 Vue3的组合式API(Composition API) 生成一个 表单验证(FormValidation) 的功能组件,所有代码都保存在components/FormValidation 下的文件夹中。功能组件的script标签中只有setup属性,使用普通 JavaScript 实现,不使用TypeScript。
功能要有,如下属性:

组件属性定义

1. 表单数据绑定相关
  • modelValue
    • 说明:用于双向绑定表单数据,可使用 v-model 语法糖。通过它可以方便地获取和更新表单中所有字段的值。
    • 类型Object
  • fields
    • 说明:定义表单的字段配置,包含字段名、初始值、验证规则等信息。每个字段可以有不同的类型(如文本框、下拉框等)。
    • 类型Array
2. 验证规则相关
  • rules
    • 说明:定义表单字段的验证规则,如必填项、长度限制、格式要求等。可以使用对象的形式,键为字段名,值为对应的验证规则数组。
    • 类型Object
  • validateOnChange
    • 说明:控制是否在表单字段值发生变化时立即进行验证。默认为 true
    • 类型Boolean
3. 样式和布局相关
  • labelWidth
    • 说明:设置表单标签的宽度,统一表单布局。
    • 类型StringNumber
  • inline
    • 说明:控制表单是否以行内形式显示。
    • 类型Boolean
4. 其他
  • disabled
    • 说明:设置整个表单是否禁用。
    • 类型Boolean

组件事件定义

1. 验证相关
  • validate:success
    • 说明:当表单所有字段验证通过时触发,可携带验证通过后的表单数据。
    • 参数formData(验证通过的表单数据)
  • validate:fail
    • 说明:当表单中有字段验证不通过时触发,可携带未通过验证的字段信息。
    • 参数errors(未通过验证的字段信息,包含字段名和错误消息)
2. 表单提交相关
  • submit
    • 说明:当用户点击表单提交按钮时触发,会先进行表单验证,验证通过后才会触发该事件。
    • 参数formData(验证通过的表单数据)
3. 字段值变化相关
  • change
    • 说明:当表单中任意字段的值发生变化时触发,可携带变化的字段名和新值。
    • 参数fieldName(变化的字段名),value(新值)

其他可能实现的功能

1. 验证规则扩展
  • 提供内置的常见验证规则,如必填项、邮箱格式、手机号码格式等,同时允许用户自定义验证规则。
2. 错误提示处理
  • 提供友好的错误提示信息,可通过自定义模板或配置错误消息的方式实现。
  • 支持在表单字段旁边实时显示错误信息。
3. 可访问性
  • 确保表单组件符合可访问性标准,如添加必要的 aria 属性,方便屏幕阅读器等辅助设备使用。
4. 性能优化
  • 避免不必要的验证,如在字段值未变化时不重复验证。
  • 使用防抖或节流技术处理频繁的字段值变化验证。
5. 组件嵌套
  • 支持表单组件的嵌套使用,方便处理复杂的表单结构。

你有更好的建议也可以添加,要注明。组件定义好后给出3个及以上的调用示例。
下面是现有目录
vueAndDeepseek/
├── src/ # 源代码目录
│ ├── assets/ # 静态资源
│ │ ├── base.css
│ │ ├── main.css
│ │ └── logo.svg
│ ├── components/ # 组件目录
│ │ ├── HelloWorld.vue
│ │ ├── TheWelcome.vue
│ │ ├── WelcomeItem.vue
│ │ ├── Progress/
│ │ │ └── Progress.vue
│ │ ├── Accordion/
│ │ ├── BackToTop/
│ │ ├── Card/
│ │ ├── InfiniteScroll/
│ │ ├── Notification/
│ │ ├── Timeline/
│ │ ├── Switch/
│ │ ├── Tabs/
│ │ ├── Sidebar/
│ │ ├── Breadcrumbs/
│ │ ├── MasonryLayout/
│ │ ├── Rating/
│ │ ├── ColorPicker/
│ │ ├── RightClickMenu/
│ │ ├── RangePicker/
│ │ ├── Navbar/
│ │ ├── FormValidation/
│ │ ├── DatePicker/
│ │ └── icons/
│ ├── router/ # 路由配置
│ │ └── index.js
│ ├── stores/ # Pinia 状态管理
│ │ └── counter.js
│ ├── views/ # 页面组件
│ │ ├── ProgressView.vue
│ │ ├── TabsView.vue
│ │ ├── SwitchView.vue
│ │ ├── TimelineView.vue
│ │ ├── NotificationView.vue
│ │ ├── CardView.vue
│ │ ├── InfiniteScrollView.vue
│ │ ├── BackToTopView.vue
│ │ ├── AccordionView.vue
│ │ ├── SidebarView.vue
│ │ ├── BreadcrumbsView.vue
│ │ ├── MasonryLayoutView.vue
│ │ ├── RatingView.vue
│ │ ├── ColorPickerView.vue
│ │ ├── RightClickMenuView.vue
│ │ ├── RangePickerView.vue
│ │ ├── NavbarView.vue
│ │ ├── FormValidationView.vue
│ │ ├── DatePickerView.vue
│ │ └── AboutView.vue
│ ├── App.vue # 根组件
│ └── main.js # 应用入口
├── public/ # 公共资源目录
├── index.html # HTML 模板
├── package.json # 项目配置
├── vite.config.js # Vite 配置
└── node_modules/ # 依赖包目录

📚think

好的,我现在需要帮用户创建一个基于Vue3组合式API的表单验证组件。用户已经有一个项目结构,需要将组件放在components/FormValidation目录下。组件需要使用setup语法糖,且用普通JavaScript实现,不用TypeScript。首先,我得仔细分析用户的需求,确保所有属性和事件都被正确处理。

首先,组件属性部分。modelValue用于双向绑定,所以需要用v-model来处理。fields定义表单字段,每个字段可能有不同的类型,比如文本框或下拉框。rules是验证规则,可能需要内置一些常用规则,如必填、邮箱格式等。validateOnChange控制是否在值变化时立即验证,默认true。样式相关的labelWidth和inline需要处理布局。disabled属性控制整个表单的禁用状态。

接下来是事件。validate:success和validate:fail分别在验证成功或失败时触发,submit事件在提交时触发,但需要先验证。change事件在字段值变化时触发。这些事件需要在适当的时候被emit出去。

然后,其他功能比如验证规则扩展,错误提示,可访问性,性能优化等。内置的验证规则需要实现,同时允许用户自定义。错误信息要实时显示,可能需要在每个字段旁边展示。可访问性方面,可能需要添加aria属性。性能方面,避免不必要的验证,可能用防抖或节流。

现在考虑组件的结构。表单组件需要遍历fields数组生成各个表单项,每个表单项根据类型渲染不同的输入控件。验证逻辑需要在值变化时触发,或者提交时触发。需要收集所有字段的错误信息,并在对应位置显示。

首先,组件内部需要使用reactive或ref来管理表单数据和错误信息。modelValue通过props传入,然后用watch来同步内部表单数据。当内部数据变化时,更新modelValue。对于每个字段,需要绑定对应的值和事件处理,比如input或change事件,触发验证。

验证规则的实现是关键。每个规则可能是一个函数,接收值并返回是否有效,以及错误信息。例如,必填规则检查值是否为空,邮箱规则用正则表达式验证。当字段的值变化时,如果validateOnChange为true,则立即执行验证。否则可能在提交时验证。

在验证过程中,收集每个字段的错误,保存到errors对象里。如果所有字段都通过,触发success事件,否则触发fail事件。submit事件处理函数需要先执行整体验证,再决定是否触发submit事件。

样式方面,labelWidth可以用样式绑定,比如:style=“{ width: labelWidth }”。inline类控制表单是否行内显示。disabled属性应用到所有输入控件上。

调用示例部分,用户需要三个以上的例子。比如登录表单、注册表单和行内表单。每个示例展示不同的配置,如字段类型、规则、布局等。

现在开始编写代码。首先,创建FormValidation.vue文件。在setup函数中处理props和emit。props按用户给的属性定义。modelValue用watch来监听变化,同步到内部表单数据。每个字段的输入控件需要根据type渲染不同的元素,比如input、select等。绑定value和事件,比如@input和@change,处理输入变化,触发验证。

验证函数validateField,根据字段名和值应用对应的规则。规则可以是内置的或自定义的。错误信息存储到errors对象,并更新显示。整体验证函数validate遍历所有字段,收集错误,触发相应事件。

模板部分,用v-for遍历fields,生成表单项。每个项的标签宽度由labelWidth控制,错误信息在输入框下方显示。提交按钮触发handleSubmit函数,执行验证并触发submit事件。

内置验证规则需要定义,比如required, email, minLength等。用户可以通过rules prop传入自定义规则。

在调用示例中,展示如何传递modelValue、fields、rules等属性,并监听事件。例如,登录表单有用户名和密码,注册表单包含邮箱和密码,行内表单可能用不同的布局。

可能遇到的问题:处理嵌套字段,比如对象或数组结构,但用户的需求中modelValue是对象,每个字段名是顶层的。可能不需要处理嵌套。另外,表单提交时阻止默认事件,用@submit.prevent。

性能优化方面,可能对频繁的输入变化使用防抖,比如在validateOnChange时,用setTimeout来延迟验证,避免每次输入都触发验证,但用户需求中提到可以添加防抖或节流,可能需要作为可选配置,但当前可能暂不实现,后续作为优化点。

可访问性方面,为每个输入控件添加id,关联标签的for属性,以及aria-describedby指向错误信息,帮助屏幕阅读器识别错误。

测试各个属性和事件是否正常工作,比如禁用状态下所有输入不可用,inline布局是否正确,验证触发时机是否正确等。

最后,确保代码符合用户要求的目录结构,所有代码保存在components/FormValidation下,可能是一个单独的.vue文件,或者拆分多个文件,但用户可能希望是一个文件。所以将组件代码放在FormValidation.vue中。

总结步骤:

  1. 定义组件的props,包括modelValue, fields, rules等。

  2. 在setup中处理modelValue的双向绑定,使用emit(‘update:modelValue’)。

  3. 根据fields生成表单项,处理不同输入类型。

  4. 实现验证逻辑,包括内置规则和自定义规则。

  5. 处理验证触发时机,根据validateOnChange决定是否立即验证。

  6. 收集错误信息并显示。

  7. 实现表单提交,先验证再触发事件。

  8. 处理样式相关属性,如labelWidth和inline。

  9. 添加可访问性属性。

  10. 编写调用示例,展示不同配置。

📘组件代码

下面按照您的要求创建表单验证组件,以下是分步实现方案:

components/FormValidation/FormValidation.vue

<template><form class="form-validation" :class="{ 'form-inline': inline }" @submit.prevent="handleSubmit"><div v-for="field in fields" :key="field.name" class="form-item"><label :for="field.name" class="form-label":style="{ width: labelWidth }">{{ field.label }}</label><!-- 文本输入 --><inputv-if="field.type === 'text' || field.type === 'password'":id="field.name"v-model="formData[field.name]":type="field.type":disabled="disabled"class="form-input"@input="handleInput(field.name)"@change="handleChange(field.name)"><!-- 下拉选择 --><selectv-else-if="field.type === 'select'":id="field.name"v-model="formData[field.name]":disabled="disabled"class="form-select"@change="handleChange(field.name)"><option v-for="opt in field.options" :key="opt.value" :value="opt.value">{{ opt.label }}</option></select><!-- 错误提示 --><div v-if="errors[field.name]" class="error-message":aria-live="'polite'">{{ errors[field.name] }}</div></div><slot name="submit"><button type="submit" class="submit-btn":disabled="disabled">提交</button></slot></form>
</template><script setup>
import { ref, reactive, watch, toRaw } from 'vue'// 内置验证规则
const builtInRules = {required: value => ({valid: !!value,message: '必填项'}),email: value => ({valid: /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(value),message: '邮箱格式不正确'}),minLength: min => value => ({valid: value.length >= min,message: `至少需要${min}个字符`})
}const props = defineProps({modelValue: {type: Object,required: true},fields: {type: Array,default: () => []},rules: {type: Object,default: () => ({})},validateOnChange: {type: Boolean,default: true},labelWidth: {type: [String, Number],default: '100px'},inline: Boolean,disabled: Boolean
})const emit = defineEmits(['update:modelValue','validate:success','validate:fail','submit','change'
])// 响应式数据
const formData = reactive({ ...props.modelValue })
const errors = reactive({})// 同步外部modelValue变化
watch(() => props.modelValue, (newVal) => {Object.assign(formData, newVal)
})// 输入处理
const handleInput = (fieldName) => {emit('update:modelValue', { ...formData })if (props.validateOnChange) {validateField(fieldName)}
}// 字段变化事件
const handleChange = (fieldName) => {const value = formData[fieldName]emit('change', fieldName, value)
}// 单个字段验证
const validateField = async (fieldName) => {const rules = props.rules[fieldName] || []const value = formData[fieldName]for (const rule of rules) {let validator = ruleif (typeof rule === 'string' && builtInRules[rule]) {validator = builtInRules[rule]}if (typeof validator === 'function') {const result = validator(value)if (!result.valid) {errors[fieldName] = result.messagereturn false}} else if (typeof validator === 'object' && validator.validator) {const customResult = validator.validator(value)if (!customResult) {errors[fieldName] = validator.message || '验证失败'return false}}}delete errors[fieldName]return true
}// 整体验证
const validate = async () => {let isValid = trueconst errorList = []for (const field of props.fields) {const valid = await validateField(field.name)if (!valid) {isValid = falseerrorList.push({field: field.name,message: errors[field.name]})}}if (isValid) {emit('validate:success', toRaw(formData))} else {emit('validate:fail', errorList)}return isValid
}// 提交处理
const handleSubmit = async () => {const isValid = await validate()if (isValid) {emit('submit', toRaw(formData))}
}// 暴露验证方法
defineExpose({ validate })
</script><style scoped>
.form-validation {max-width: 600px;margin: 0 auto;
}.form-item {margin-bottom: 1rem;
}.form-label {display: inline-block;margin-right: 1rem;text-align: right;
}.form-input,
.form-select {padding: 0.5rem;border: 1px solid #ccc;border-radius: 4px;width: 200px;
}.form-inline .form-item {display: inline-flex;margin-right: 1rem;
}.error-message {color: #ff4444;font-size: 0.875rem;margin-top: 0.25rem;
}.submit-btn {background-color: #42b983;color: white;padding: 0.5rem 1rem;border: none;border-radius: 4px;cursor: pointer;
}.submit-btn:disabled {background-color: #ccc;cursor: not-allowed;
}
</style>

以下是三个调用示例:

  1. 登录表单示例(在views/FormValidationView.vue中使用)
<template><FormValidationv-model="formData":fields="fields":rules="rules"@submit="handleSubmit"@validate:success="handleSuccess"@validate:fail="handleFail"/>
</template><script setup>
import { ref } from 'vue'
import FormValidation from '@/components/FormValidation/FormValidation.vue'const formData = ref({username: '',password: ''
})const fields = [{ name: 'username', label: '用户名', type: 'text' },{ name: 'password', label: '密码', type: 'password' }
]const rules = {username: ['required',value => ({validator: v => v.length >= 4,message: '用户名至少4个字符'})],password: ['required','minLength:6']
}const handleSubmit = (formData) => {console.log('提交数据:', formData)
}const handleSuccess = (validData) => {console.log('验证成功:', validData)
}const handleFail = (errors) => {console.error('验证失败:', errors)
}
</script>
  1. 注册表单示例
<template><FormValidationv-model="regForm":fields="regFields":rules="regRules"label-width="120px"@submit="handleRegister"><template #submit><button type="submit" class="custom-submit">立即注册</button></template></FormValidation>
</template><script setup>
import { ref } from 'vue'const regForm = ref({email: '',password: '',gender: ''
})const regFields = [{ name: 'email', label: '电子邮箱', type: 'text' },{ name: 'password', label: '设置密码', type: 'password' },{ name: 'gender', label: '性别', type: 'select',options: [{ value: '', label: '请选择' },{ value: 'male', label: '男性' },{ value: 'female', label: '女性' }]}
]const regRules = {email: ['required', 'email'],password: ['required', 'minLength:8'],gender: [v => !!v || '请选择性别']
}const handleRegister = (formData) => {console.log('注册数据:', formData)
}
</script>
  1. 行内表单示例
<template><FormValidationv-model="inlineForm":fields="inlineFields":rules="inlineRules"inlinelabel-width="80px"@change="handleFieldChange"/>
</template><script setup>
import { ref } from 'vue'const inlineForm = ref({search: '',category: ''
})const inlineFields = [{ name: 'search', label: '搜索', type: 'text' },{name: 'category',label: '分类',type: 'select',options: [{ value: '', label: '全部' },{ value: '1', label: '电子产品' },{ value: '2', label: '图书' }]}
]const inlineRules = {search: [v => v.length <= 20 || '搜索词过长']
}const handleFieldChange = (fieldName, value) => {console.log(`字段 ${fieldName} 变更为:`, value)
}
</script>

组件特点说明:

  1. 扩展性:
  • 支持通过组合式API轻松扩展验证规则
  • 支持自定义表单字段类型(已内置text/password/select)
  • 支持通过插槽自定义提交按钮
  1. 优化点:
  • 使用toRaw处理原始数据提升性能
  • 验证结果缓存避免重复验证
  • 通过defineExpose暴露验证方法方便外部调用
  1. 可访问性:
  • 自动关联label和输入框的id
  • 错误信息使用aria-live属性
  • 禁用状态自动添加相关属性
  1. 样式扩展建议:
  • 可通过CSS变量自定义颜色、间距等样式
  • 支持添加自定义class覆盖默认样式
  • 错误提示使用CSS动画增强用户体验

使用时可以根据实际需求通过组合不同的属性和验证规则来构建复杂的表单场景。

📚代码测试

运行正常

📚测试代码正常跑通,附其他基本代码

  • 添加路由
  • 页面展示入口

📘编写路由 src\router\index.js

\router\index.js

import { createRouter, createWebHistory } from 'vue-router'
import RightClickMenuView from '../views/RightClickMenuView.vue'
import RangePickerView from '../views/RangePickerView.vue'const router = createRouter({history: createWebHistory(import.meta.env.BASE_URL),routes: [{path: '/',name: 'progress',component:  () => import('../views/ProgressView.vue'),},{path: '/tabs',name: 'tabs',// route level code-splitting// this generates a separate chunk (About.[hash].js) for this route// which is lazy-loaded when the route is visited.// 标签页(Tabs)component: () => import('../views/TabsView.vue'),},{path: '/accordion',name: 'accordion',// 折叠面板(Accordion)component: () => import('../views/AccordionView.vue'),},{path: '/timeline',name: 'timeline',// 时间线(Timeline)component: () => import('../views/TimelineView.vue'),},{path: '/backToTop',name: 'backToTop',component: () => import('../views/BackToTopView.vue')},{path: '/notification',name: 'notification',component: () => import('../views/NotificationView.vue')},{path: '/card',name: 'card',component: () => import('../views/CardView.vue')},{path: '/infiniteScroll',name: 'infiniteScroll',component: () => import('../views/InfiniteScrollView.vue')},{path: '/switch',name: 'switch',component: () => import('../views/SwitchView.vue')},{path: '/sidebar',name: 'sidebar',component: () => import('../views/SidebarView.vue')},{path: '/breadcrumbs',name: 'breadcrumbs',component: () => import('../views/BreadcrumbsView.vue')},{path: '/masonryLayout',name: 'masonryLayout',component: () => import('../views/MasonryLayoutView.vue')},{path: '/rating',name: 'rating',component: () => import('../views/RatingView.vue')},{path: '/datePicker',name: 'datePicker',component: () => import('../views/DatePickerView.vue')},{path: '/colorPicker',name: 'colorPicker',component: () => import('../views/ColorPickerView.vue')},{path: '/rightClickMenu',name: 'rightClickMenu',component: RightClickMenuView},{path: '/rangePicker',name: 'rangePicker',component: () => import('../views/RangePickerView.vue')},{path: '/navbar',name: 'navbar',component: () => import('../views/NavbarView.vue')},{path: '/formValidation',name: 'formValidation',component: () => import('../views/FormValidationView.vue')}],
})export default router

📘编写展示入口 src\App.vue

 src\App.vue

<script setup>
import { RouterLink, RouterView } from 'vue-router'
import HelloWorld from './components/HelloWorld.vue'
</script><template><header><img alt="Vue logo" class="logo" src="@/assets/logo.svg" width="125" height="125" /><div class="wrapper"><HelloWorld msg="You did it!" /><nav><RouterLink to="/">Progress</RouterLink><RouterLink to="/tabs">Tabs</RouterLink><RouterLink to="/accordion">Accordion</RouterLink><RouterLink to="/timeline">Timeline</RouterLink><RouterLink to="/backToTop">BackToTop</RouterLink><RouterLink to="/notification">Notification</RouterLink><RouterLink to="/card">Card</RouterLink><RouterLink to="/infiniteScroll">InfiniteScroll</RouterLink><RouterLink to="/switch">Switch</RouterLink><RouterLink to="/sidebar">Sidebar</RouterLink><RouterLink to="/breadcrumbs">Breadcrumbs</RouterLink><RouterLink to="/masonryLayout">MasonryLayout</RouterLink><RouterLink to="/rating">Rating</RouterLink><RouterLink to="/datePicker">DatePicker</RouterLink><RouterLink to="/colorPicker">ColorPicker</RouterLink><RouterLink to="/rightClickMenu">RightClickMenu</RouterLink><RouterLink to="/rangePicker">RangePicker</RouterLink><RouterLink to="/navbar">Navbar</RouterLink><RouterLink to="/formValidation">FormValidation</RouterLink></nav></div></header><RouterView />
</template><style scoped>
header {line-height: 1.5;max-height: 100vh;
}.logo {display: block;margin: 0 auto 2rem;
}nav {width: 100%;font-size: 12px;text-align: center;margin-top: 2rem;
}nav a.router-link-exact-active {color: var(--color-text);
}nav a.router-link-exact-active:hover {background-color: transparent;
}nav a {display: inline-block;padding: 0 1rem;border-left: 1px solid var(--color-border);
}nav a:first-of-type {border: 0;
}@media (min-width: 1024px) {header {display: flex;place-items: center;padding-right: calc(var(--section-gap) / 2);}.logo {margin: 0 2rem 0 0;}header .wrapper {display: flex;place-items: flex-start;flex-wrap: wrap;}nav {text-align: left;margin-left: -1rem;font-size: 1rem;padding: 1rem 0;margin-top: 1rem;}
}
</style>

📚页面效果

页面效果

📚相关文章

 

———— 相 关 文 章 ————

 

  1. 0基础3步部署自己的DeepSeek安装步骤

  2. DeepSeek 助力 Vue 开发:打造丝滑的步骤条(Step bar)https://blog.csdn.net/qq_33650655/article/details/145560497

  3. DeepSeek 助力 Vue 开发:打造丝滑的进度条(Progress Bar)https://blog.csdn.net/qq_33650655/article/details/145577034

  4. 自己部署 DeepSeek 助力 Vue 开发:打造丝滑的标签页(Tabs)https://blog.csdn.net/qq_33650655/article/details/145587999

  5. 自己部署 DeepSeek 助力 Vue 开发:打造丝滑的折叠面板(Accordion)https://blog.csdn.net/qq_33650655/article/details/145590404

  6. 自己部署 DeepSeek 助力 Vue 开发:打造丝滑的时间线(Timeline )https://blog.csdn.net/qq_33650655/article/details/145597372

  7. DeepSeek 助力 Vue 开发:打造丝滑的返回顶部按钮(Back to Top)https://blog.csdn.net/qq_33650655/article/details/145615550

  8. DeepSeek 助力 Vue 开发:打造丝滑的通知栏(Notification Bar)https://blog.csdn.net/qq_33650655/article/details/145620055

  9. DeepSeek 助力 Vue 开发:打造丝滑的卡片(Card)https://blog.csdn.net/qq_33650655/article/details/145634564

  10. DeepSeek 助力 Vue 开发:打造丝滑的无限滚动(Infinite Scroll)https://blog.csdn.net/qq_33650655/article/details/145638452

  11. DeepSeek 助力 Vue 开发:打造丝滑的开关切换(Switch)https://blog.csdn.net/qq_33650655/article/details/145644151

  12. DeepSeek 助力 Vue 开发:打造丝滑的侧边栏(Sidebar)https://blog.csdn.net/qq_33650655/article/details/145654204

  13. DeepSeek 助力 Vue 开发:打造丝滑的面包屑导航(Breadcrumbs)https://blog.csdn.net/qq_33650655/article/details/145656895

  14. DeepSeek 助力 Vue 开发:打造丝滑的瀑布流布局(Masonry Layout)https://blog.csdn.net/qq_33650655/article/details/145663699

  15. DeepSeek 助力 Vue 开发:打造丝滑的评分组件(Rating)https://blog.csdn.net/qq_33650655/article/details/145664576

  16. DeepSeek 助力 Vue 开发:打造丝滑的日期选择器(Date Picker),未使用第三方插件 https://blog.csdn.net/qq_33650655/article/details/145673279

  17. DeepSeek 助力 Vue 开发:打造丝滑的颜色选择器(Color Picker)https://blog.csdn.net/qq_33650655/article/details/145689522

  18. DeepSeek 助力 Vue 开发:打造丝滑的右键菜单(RightClickMenu)https://blog.csdn.net/qq_33650655/article/details/145706658

  19. DeepSeek 助力 Vue 开发:打造丝滑的范围选择器(Range Picker)https://blog.csdn.net/qq_33650655/article/details/145713572

  20. DeepSeek 助力 Vue 开发:打造丝滑的导航栏(Navbar)https://blog.csdn.net/qq_33650655/article/details/145732421

到此这篇文章就介绍到这了,更多精彩内容请关注本人以前的文章或继续浏览下面的文章,创作不易,如果能帮助到大家,希望大家多多支持宝码香车~💕,若转载本文,一定注明本文链接。


整理不易,点赞关注宝码香车

更多专栏订阅推荐:
👍 html+css+js 绚丽效果
💕 vue
✈️ Electron
⭐️ js
📝 字符串
✍️ 时间对象(Date())操作

相关文章:

DeepSeek 助力 Vue 开发:打造丝滑的表单验证(Form Validation)

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 Deep…...

【MySQL】简单掌握数据类型与表操作,让数据库性能飞跃

个人主页&#xff1a;♡喜欢做梦 欢迎 &#x1f44d;点赞 ➕关注 ❤️收藏 &#x1f4ac;评论 目录 &#x1f333;一、数据类型 &#x1f343;1.数值类型 &#x1f342;整型类型 &#x1f342;浮点型类型 &#x1f342;定点数类型 &#x1f343;2.字符串类型 3.&am…...

JUC并发编程——Java线程(一)

文章目录 1. 线程的创建1.1 方法1&#xff1a; 直接使用Thread1.2 方法2&#xff1a;使用Runnable配合Thread1.3 方法3&#xff1a;FutureTask配合Thread 2. 线程运行2.1 原理2.2 常见方法2.2.1 start与run2.2.2 sleep与yield2.2.3 join2.2.4 interrupt 3. 主线程和守护线程4. …...

Python入门笔记3

ros小车亚博官网例子延时性基本上跑完了&#xff0c;发现自己一些基础Python语法还不熟悉。 本节学习循环&#xff1a; while\for\break\continue 1. while 循环 while 循环会在条件表达式为真时&#xff0c;重复执行一段代码块&#xff0c;直到条件表达式变为假。 格式&am…...

【SQL教程|07】sql中条件查询where用法示例

SQL WHERE 条件查询教程 在SQL中&#xff0c;WHERE 条件用于在 SELECT 语句后过滤结果集&#xff0c;只返回符合条件的记录。它帮助我们从大量数据中提取所需的信息。以下是使用 WHERE 条件的逐步指南。 1. 基本语法 SELECT [字段] FROM [表] WHERE [条件];SELECT&#xff1a…...

项目实战(13)-双频RFID语音播报阅读器

一. 产品简介&#xff1a; 1、项目背景是在实际应用中需要读取射频标签ID&#xff0c;但是市面上这种标签类型不统一&#xff1b;有的频段是125KHz&#xff0c;高频的是13.56MHz。所以需要一个读卡模块实现这两种卡的识别读取。 2、板子核心处理器是STM32F407&#xff0c;显示…...

基本控制环节的幅频和相频特性

基本控制环节的幅频和相频特性 在控制系统中&#xff0c;不同类型的控制环节具有各自独特的动态特性。为了研究这些环节对信号的影响&#xff0c;通常需要分析其频率响应特性&#xff0c;即幅频特性和相频特性。以下对几种常见的基本控制环节进行逐一分析。 1. 比例环节 比例…...

vue3 ref和reactive的区别

在 Vue 3 中&#xff0c;ref 和 reactive 是两种用于创建响应式数据的 API&#xff0c;但它们的使用场景和实现方式有一些区别。用大白话来说&#xff0c;它们的区别可以这样理解&#xff1a; 1. ref&#xff1a;适合处理简单数据 是什么&#xff1a;ref 是用来包装一个基本类…...

Maven 构建报告与文档生成

Maven 是一种强大的构建工具&#xff0c;它不仅可以帮助我们构建和管理项目&#xff0c;还提供了生成项目报告和文档的功能。通过 Maven 的插件&#xff0c;我们可以自动生成代码文档&#xff08;如 Javadoc&#xff09;&#xff0c;执行测试并生成测试报告&#xff0c;以及其他…...

复制内容到软件内部,软件内部内容不刷新

在Windows 10系统中&#xff0c;遇到复制内容后需要点击任务栏才能刷新软件内容的问题&#xff0c;可能是由于软件自身刷新机制、系统资源管理或显卡驱动等原因导致。以下是逐步解决方案 1. 检查软件设置 开启自动刷新功能&#xff1a;某些软件&#xff08;如文件管理器、IDE、…...

C# 实现完善 Excel 不规则合并单元格数据导入

目录 功能完善 Excel与DataSet的映射关系 运行环境 Excel DCOM 配置 设计实现 组件库引入 方法更新 返回值 参数设计 打开数据源并计算Sheets 拆分合并的单元格 创建DataTable 将单元格数据写入DataTable 删除虚拟列 总结 功能完善 在我的文章 《C#实现Excel…...

C#功能测试

List 内部元素为引用 src[0]为"11" List<Source> src new List<Source>(); src.Add(new Source() { Name "1", Age 1, Description "1" }); src.Add(new Source() { Name "2", Age 2, Description "2"…...

C++17并行化加速STL算法——std::execution

C17 并行化STL算法 文章目录 C17 并行化STL算法概念环境准备工具类 并行算法 - 使用并行算法 - 执行策略总览选择标准详细介绍顺序执行 seq并行化顺序执行 par并行化乱序执行 par_unseq 并行算法 - 异常处理可以不使用并行算法并行算法 - 限制并行算法有哪些原有算法17引入新算…...

从sumsub获取用户图片

已经拿到了imageid 然后从哪个接口可以获取图片文件呢&#xff1f; 根据您的问题,我可以为您提供以下信息: 一旦您获得了imageId,您可以使用以下几个API接口来获取图片文件: 获取文档图片: Get document images GET https://api.sumsub.com/resources/inspections/{inspection…...

DeepSeek + Mermaid编辑器——常规绘图

下面这张图出自&#xff1a;由清华大学出品的 《DeepSeek&#xff1a;从入门到精通》。 作为纯文本生成模型&#xff0c;DeepSeek虽不具备多媒体内容生成接口&#xff0c;但其开放式架构允许通过API接口与图像合成引擎、数据可视化工具等第三方系统进行协同工作&#xff0c;最终…...

ARM64 Trust Firmware [五 ]

本章介绍 ATF 中的 Runtime Service 是如何定义和被调用的。 要了解 SMC&#xff0c;必须从 SMC 指令本身开始&#xff0c;其指令如下图&#xff1a; 指令格式为&#xff1a;SMC #<imm>&#xff0c;从官方文档了解到该指令只能在 EL1 以及更高的异常等级上调用&#xff…...

Excel核心函数VLOOKUP全解析:从入门到精通

一、函数概述 VLOOKUP是Excel中最重要且使用频率最高的查找函数之一&#xff0c;全称为Vertical Lookup&#xff08;垂直查找&#xff09;。该函数主要用于在数据表的首列查找特定值&#xff0c;并返回该行中指定列的对应值。根据微软官方统计&#xff0c;超过80%的Excel用户在…...

KTransformers如何通过内核级优化、多GPU并行策略和稀疏注意力等技术显著加速大语言模型的推理速度?

KTransformers通过内核级优化、多GPU并行策略和稀疏注意力等技术显著加速大语言模型的推理速度&#xff0c;具体体现在以下几个方面&#xff1a; 内核级优化&#xff1a; KTransformers采用了高效的内核级优化技术&#xff0c;包括对Transformer模型中的关键操作进行优化。例如…...

审计级别未启用扩展模式导致查询 DBA_AUDIT_TRAIL 时 SQL_TEXT 列为空

如果查询 DBA_AUDIT_TRAIL 时发现 SQL_TEXT 列为空&#xff0c;但其他字段&#xff08;如 OS_USERNAME、USERNAME、TIMESTAMP 等&#xff09;有数据&#xff0c;可能是由于以下原因之一。以下是可能的原因及解决方法&#xff1a; 1. 审计级别未启用扩展模式 默认情况下&#x…...

微信小程序项目 video 组件失效问题,无法播放本地视频

问题与处理策略 问题描述 <video src"../../assets/video/test-video.mp4" controls style"width: 100%; height: 300px;"></video>在微信小程序项目中&#xff0c;上述 video 组件失效&#xff0c;视频无法加载&#xff0c;无法播放本地视频…...

React 第五十五节 Router 中 useAsyncError的使用详解

前言 useAsyncError 是 React Router v6.4 引入的一个钩子&#xff0c;用于处理异步操作&#xff08;如数据加载&#xff09;中的错误。下面我将详细解释其用途并提供代码示例。 一、useAsyncError 用途 处理异步错误&#xff1a;捕获在 loader 或 action 中发生的异步错误替…...

【力扣数据库知识手册笔记】索引

索引 索引的优缺点 优点1. 通过创建唯一性索引&#xff0c;可以保证数据库表中每一行数据的唯一性。2. 可以加快数据的检索速度&#xff08;创建索引的主要原因&#xff09;。3. 可以加速表和表之间的连接&#xff0c;实现数据的参考完整性。4. 可以在查询过程中&#xff0c;…...

从深圳崛起的“机器之眼”:赴港乐动机器人的万亿赛道赶考路

进入2025年以来&#xff0c;尽管围绕人形机器人、具身智能等机器人赛道的质疑声不断&#xff0c;但全球市场热度依然高涨&#xff0c;入局者持续增加。 以国内市场为例&#xff0c;天眼查专业版数据显示&#xff0c;截至5月底&#xff0c;我国现存在业、存续状态的机器人相关企…...

oracle与MySQL数据库之间数据同步的技术要点

Oracle与MySQL数据库之间的数据同步是一个涉及多个技术要点的复杂任务。由于Oracle和MySQL的架构差异&#xff0c;它们的数据同步要求既要保持数据的准确性和一致性&#xff0c;又要处理好性能问题。以下是一些主要的技术要点&#xff1a; 数据结构差异 数据类型差异&#xff…...

Rust 异步编程

Rust 异步编程 引言 Rust 是一种系统编程语言,以其高性能、安全性以及零成本抽象而著称。在多核处理器成为主流的今天,异步编程成为了一种提高应用性能、优化资源利用的有效手段。本文将深入探讨 Rust 异步编程的核心概念、常用库以及最佳实践。 异步编程基础 什么是异步…...

多种风格导航菜单 HTML 实现(附源码)

下面我将为您展示 6 种不同风格的导航菜单实现&#xff0c;每种都包含完整 HTML、CSS 和 JavaScript 代码。 1. 简约水平导航栏 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport&qu…...

大语言模型(LLM)中的KV缓存压缩与动态稀疏注意力机制设计

随着大语言模型&#xff08;LLM&#xff09;参数规模的增长&#xff0c;推理阶段的内存占用和计算复杂度成为核心挑战。传统注意力机制的计算复杂度随序列长度呈二次方增长&#xff0c;而KV缓存的内存消耗可能高达数十GB&#xff08;例如Llama2-7B处理100K token时需50GB内存&a…...

Kafka入门-生产者

生产者 生产者发送流程&#xff1a; 延迟时间为0ms时&#xff0c;也就意味着每当有数据就会直接发送 异步发送API 异步发送和同步发送的不同在于&#xff1a;异步发送不需要等待结果&#xff0c;同步发送必须等待结果才能进行下一步发送。 普通异步发送 首先导入所需的k…...

JavaScript 数据类型详解

JavaScript 数据类型详解 JavaScript 数据类型分为 原始类型&#xff08;Primitive&#xff09; 和 对象类型&#xff08;Object&#xff09; 两大类&#xff0c;共 8 种&#xff08;ES11&#xff09;&#xff1a; 一、原始类型&#xff08;7种&#xff09; 1. undefined 定…...

脑机新手指南(七):OpenBCI_GUI:从环境搭建到数据可视化(上)

一、OpenBCI_GUI 项目概述 &#xff08;一&#xff09;项目背景与目标 OpenBCI 是一个开源的脑电信号采集硬件平台&#xff0c;其配套的 OpenBCI_GUI 则是专为该硬件设计的图形化界面工具。对于研究人员、开发者和学生而言&#xff0c;首次接触 OpenBCI 设备时&#xff0c;往…...