51租官网:首页、关于我们、车型展示、用户故事、联系我们五大版块

This commit is contained in:
root 2026-03-28 18:38:26 +08:00
commit 138ff70612
16 changed files with 1977 additions and 0 deletions

24
.gitignore vendored Normal file
View File

@ -0,0 +1,24 @@
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*
node_modules
dist
dist-ssr
*.local
# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

3
.vscode/extensions.json vendored Normal file
View File

@ -0,0 +1,3 @@
{
"recommendations": ["Vue.volar"]
}

5
README.md Normal file
View File

@ -0,0 +1,5 @@
# Vue 3 + Vite
This template should help get you started developing with Vue 3 in Vite. The template uses Vue 3 `<script setup>` SFCs, check out the [script setup docs](https://v3.vuejs.org/api/sfc-script-setup.html#sfc-script-setup) to learn more.
Learn more about IDE Support for Vue in the [Vue Docs Scaling up Guide](https://vuejs.org/guide/scaling-up/tooling.html#ide-support).

14
index.html Normal file
View File

@ -0,0 +1,14 @@
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<link rel="icon" type="image/svg+xml" href="data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><rect fill='%23FF6B00' width='100' height='100' rx='20'/><text x='50' y='65' font-size='50' font-weight='bold' text-anchor='middle' fill='white'>51</text></svg>">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="description" content="51租 - 专业电动车租赁平台,让出行更简单">
<title>51租 - 让出行更简单 | 51bike.online</title>
</head>
<body>
<div id="app"></div>
<script type="module" src="/src/main.js"></script>
</body>
</html>

1098
package-lock.json generated Normal file

File diff suppressed because it is too large Load Diff

18
package.json Normal file
View File

@ -0,0 +1,18 @@
{
"name": "51bike-official",
"private": true,
"version": "0.0.0",
"type": "module",
"scripts": {
"dev": "vite",
"build": "vite build",
"preview": "vite preview"
},
"dependencies": {
"vue": "^3.5.30"
},
"devDependencies": {
"@vitejs/plugin-vue": "^6.0.5",
"vite": "^8.0.1"
}
}

1
public/favicon.svg Normal file

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 9.3 KiB

24
public/icons.svg Normal file
View File

@ -0,0 +1,24 @@
<svg xmlns="http://www.w3.org/2000/svg">
<symbol id="bluesky-icon" viewBox="0 0 16 17">
<g clip-path="url(#bluesky-clip)"><path fill="#08060d" d="M7.75 7.735c-.693-1.348-2.58-3.86-4.334-5.097-1.68-1.187-2.32-.981-2.74-.79C.188 2.065.1 2.812.1 3.251s.241 3.602.398 4.13c.52 1.744 2.367 2.333 4.07 2.145-2.495.37-4.71 1.278-1.805 4.512 3.196 3.309 4.38-.71 4.987-2.746.608 2.036 1.307 5.91 4.93 2.746 2.72-2.746.747-4.143-1.747-4.512 1.702.189 3.55-.4 4.07-2.145.156-.528.397-3.691.397-4.13s-.088-1.186-.575-1.406c-.42-.19-1.06-.395-2.741.79-1.755 1.24-3.64 3.752-4.334 5.099"/></g>
<defs><clipPath id="bluesky-clip"><path fill="#fff" d="M.1.85h15.3v15.3H.1z"/></clipPath></defs>
</symbol>
<symbol id="discord-icon" viewBox="0 0 20 19">
<path fill="#08060d" d="M16.224 3.768a14.5 14.5 0 0 0-3.67-1.153c-.158.286-.343.67-.47.976a13.5 13.5 0 0 0-4.067 0c-.128-.306-.317-.69-.476-.976A14.4 14.4 0 0 0 3.868 3.77C1.546 7.28.916 10.703 1.231 14.077a14.7 14.7 0 0 0 4.5 2.306q.545-.748.965-1.587a9.5 9.5 0 0 1-1.518-.74q.191-.14.372-.293c2.927 1.369 6.107 1.369 8.999 0q.183.152.372.294-.723.437-1.52.74.418.838.963 1.588a14.6 14.6 0 0 0 4.504-2.308c.37-3.911-.63-7.302-2.644-10.309m-9.13 8.234c-.878 0-1.599-.82-1.599-1.82 0-.998.705-1.82 1.6-1.82.894 0 1.614.82 1.599 1.82.001 1-.705 1.82-1.6 1.82m5.91 0c-.878 0-1.599-.82-1.599-1.82 0-.998.705-1.82 1.6-1.82.893 0 1.614.82 1.599 1.82 0 1-.706 1.82-1.6 1.82"/>
</symbol>
<symbol id="documentation-icon" viewBox="0 0 21 20">
<path fill="none" stroke="#aa3bff" stroke-linecap="round" stroke-linejoin="round" stroke-width="1.35" d="m15.5 13.333 1.533 1.322c.645.555.967.833.967 1.178s-.322.623-.967 1.179L15.5 18.333m-3.333-5-1.534 1.322c-.644.555-.966.833-.966 1.178s.322.623.966 1.179l1.534 1.321"/>
<path fill="none" stroke="#aa3bff" stroke-linecap="round" stroke-linejoin="round" stroke-width="1.35" d="M17.167 10.836v-4.32c0-1.41 0-2.117-.224-2.68-.359-.906-1.118-1.621-2.08-1.96-.599-.21-1.349-.21-2.848-.21-2.623 0-3.935 0-4.983.369-1.684.591-3.013 1.842-3.641 3.428C3 6.449 3 7.684 3 10.154v2.122c0 2.558 0 3.838.706 4.726q.306.383.713.671c.76.536 1.79.64 3.581.66"/>
<path fill="none" stroke="#aa3bff" stroke-linecap="round" stroke-linejoin="round" stroke-width="1.35" d="M3 10a2.78 2.78 0 0 1 2.778-2.778c.555 0 1.209.097 1.748-.047.48-.129.854-.503.982-.982.145-.54.048-1.194.048-1.749a2.78 2.78 0 0 1 2.777-2.777"/>
</symbol>
<symbol id="github-icon" viewBox="0 0 19 19">
<path fill="#08060d" fill-rule="evenodd" d="M9.356 1.85C5.05 1.85 1.57 5.356 1.57 9.694a7.84 7.84 0 0 0 5.324 7.44c.387.079.528-.168.528-.376 0-.182-.013-.805-.013-1.454-2.165.467-2.616-.935-2.616-.935-.349-.91-.864-1.143-.864-1.143-.71-.48.051-.48.051-.48.787.051 1.2.805 1.2.805.695 1.194 1.817.857 2.268.649.064-.507.27-.857.49-1.052-1.728-.182-3.545-.857-3.545-3.87 0-.857.31-1.558.8-2.104-.078-.195-.349-1 .077-2.078 0 0 .657-.208 2.14.805a7.5 7.5 0 0 1 1.946-.26c.657 0 1.328.092 1.946.26 1.483-1.013 2.14-.805 2.14-.805.426 1.078.155 1.883.078 2.078.502.546.799 1.247.799 2.104 0 3.013-1.818 3.675-3.558 3.87.284.247.528.714.528 1.454 0 1.052-.012 1.896-.012 2.156 0 .208.142.455.528.377a7.84 7.84 0 0 0 5.324-7.441c.013-4.338-3.48-7.844-7.773-7.844" clip-rule="evenodd"/>
</symbol>
<symbol id="social-icon" viewBox="0 0 20 20">
<path fill="none" stroke="#aa3bff" stroke-linecap="round" stroke-linejoin="round" stroke-width="1.35" d="M12.5 6.667a4.167 4.167 0 1 0-8.334 0 4.167 4.167 0 0 0 8.334 0"/>
<path fill="none" stroke="#aa3bff" stroke-linecap="round" stroke-linejoin="round" stroke-width="1.35" d="M2.5 16.667a5.833 5.833 0 0 1 8.75-5.053m3.837.474.513 1.035c.07.144.257.282.414.309l.93.155c.596.1.736.536.307.965l-.723.73a.64.64 0 0 0-.152.531l.207.903c.164.715-.213.991-.84.618l-.872-.52a.63.63 0 0 0-.577 0l-.872.52c-.624.373-1.003.094-.84-.618l.207-.903a.64.64 0 0 0-.152-.532l-.723-.729c-.426-.43-.289-.864.306-.964l.93-.156a.64.64 0 0 0 .412-.31l.513-1.034c.28-.562.735-.562 1.012 0"/>
</symbol>
<symbol id="x-icon" viewBox="0 0 19 19">
<path fill="#08060d" fill-rule="evenodd" d="M1.893 1.98c.052.072 1.245 1.769 2.653 3.77l2.892 4.114c.183.261.333.48.333.486s-.068.089-.152.183l-.522.593-.765.867-3.597 4.087c-.375.426-.734.834-.798.905a1 1 0 0 0-.118.148c0 .01.236.017.664.017h.663l.729-.83c.4-.457.796-.906.879-.999a692 692 0 0 0 1.794-2.038c.034-.037.301-.34.594-.675l.551-.624.345-.392a7 7 0 0 1 .34-.374c.006 0 .93 1.306 2.052 2.903l2.084 2.965.045.063h2.275c1.87 0 2.273-.003 2.266-.021-.008-.02-1.098-1.572-3.894-5.547-2.013-2.862-2.28-3.246-2.273-3.266.008-.019.282-.332 2.085-2.38l2-2.274 1.567-1.782c.022-.028-.016-.03-.65-.03h-.674l-.3.342a871 871 0 0 1-1.782 2.025c-.067.075-.405.458-.75.852a100 100 0 0 1-.803.91c-.148.172-.299.344-.99 1.127-.304.343-.32.358-.345.327-.015-.019-.904-1.282-1.976-2.808L6.365 1.85H1.8zm1.782.91 8.078 11.294c.772 1.08 1.413 1.973 1.425 1.984.016.017.241.02 1.05.017l1.03-.004-2.694-3.766L7.796 5.75 5.722 2.852l-1.039-.004-1.039-.004z" clip-rule="evenodd"/>
</symbol>
</svg>

After

Width:  |  Height:  |  Size: 4.9 KiB

229
src/App.vue Normal file
View File

@ -0,0 +1,229 @@
<template>
<div id="app">
<!-- 导航栏 -->
<header class="header">
<div class="container">
<a href="#" class="logo">
<span class="logo-icon">51</span>
<span>51</span>
</a>
<nav class="nav">
<a href="#about">关于我们</a>
<a href="#models">车型展示</a>
<a href="#stories">用户故事</a>
<a href="#contact">联系我们</a>
</nav>
</div>
</header>
<!-- 页面内容 -->
<main>
<!-- Hero 区域 -->
<section class="hero" id="hero">
<div class="container">
<div class="hero-content">
<h1>让出行更简单</h1>
<p>专业电动车租赁平台多车型统一管理助您高效运营</p>
<div class="hero-buttons">
<a href="#models" class="btn btn-primary">查看车型</a>
<a href="#contact" class="btn btn-secondary">联系我们</a>
</div>
</div>
</div>
</section>
<!-- 关于我们 -->
<section class="section" id="about">
<div class="container">
<div class="section-title">
<h2>关于51租</h2>
</div>
<div class="about-content">
<div class="about-text">
<p>51租是一家专业的电动车租赁平台隶属于51bike在线生态我们致力于为骑手提供便捷的租车服务为运营商提供高效的车辆管理解决方案</p>
<p>平台支持多种车型统一管理订单实时追踪财务一键结算让运营效率提升300%无论是个人骑手还是连锁运营商都能在这里找到最适合的解决方案</p>
</div>
<div class="about-image">
<img src="https://images.unsplash.com/photo-1497366216548-37526070297c?w=600&h=400&fit=crop" alt="51租团队">
</div>
</div>
</div>
</section>
<!-- 车型展示 -->
<section class="section section-gray" id="models">
<div class="container">
<div class="section-title">
<h2>我们的车型</h2>
</div>
<div class="models-grid">
<div class="model-card" v-for="model in models" :key="model.name">
<img :src="model.image" :alt="model.name">
<div class="model-info">
<div class="model-name">{{ model.name }}</div>
<div class="model-price">{{ model.price }}</div>
<div class="model-desc">{{ model.desc }}</div>
</div>
</div>
</div>
</div>
</section>
<!-- 用户故事 -->
<section class="section" id="stories">
<div class="container">
<div class="section-title">
<h2>他们与51租同行</h2>
</div>
<div class="stories-grid">
<div class="story-card" v-for="story in stories" :key="story.author">
<img :src="story.avatar" :alt="story.author" class="story-avatar">
<div class="story-quote">"{{ story.quote }}"</div>
<div class="story-author">{{ story.author }}</div>
</div>
</div>
</div>
</section>
<!-- 联系我们 -->
<section class="section section-gray" id="contact">
<div class="container">
<div class="section-title">
<h2>联系我们</h2>
</div>
<div class="contact-content">
<div class="contact-info">
<div class="contact-item">
<div class="contact-icon">📍</div>
<div class="contact-text">
<h4>地址</h4>
<p>全国服务热线</p>
</div>
</div>
<div class="contact-item">
<div class="contact-icon">📞</div>
<div class="contact-text">
<h4>电话</h4>
<p>400-888-8888</p>
</div>
</div>
<div class="contact-item">
<div class="contact-icon"></div>
<div class="contact-text">
<h4>邮箱</h4>
<p>contact@51bike.online</p>
</div>
</div>
<div class="contact-item">
<div class="contact-icon">💬</div>
<div class="contact-text">
<h4>加盟微信</h4>
<p>扫码添加客服</p>
</div>
</div>
</div>
<div class="contact-form">
<form @submit.prevent="handleSubmit">
<div class="form-group">
<label>您的姓名</label>
<input type="text" v-model="form.name" placeholder="请输入姓名" required>
</div>
<div class="form-group">
<label>联系电话</label>
<input type="tel" v-model="form.phone" placeholder="请输入手机号" required>
</div>
<div class="form-group">
<label>留言内容</label>
<textarea v-model="form.message" placeholder="请输入留言内容" required></textarea>
</div>
<button type="submit" class="btn btn-primary" style="width: 100%;">提交留言</button>
</form>
</div>
</div>
</div>
</section>
</main>
<!-- Footer -->
<footer class="footer">
<div class="container">
<div class="footer-content">
<div class="footer-links">
<a href="https://admin.51bike.online" target="_blank">管理后台</a>
<a href="https://store.51bike.online" target="_blank">门店端</a>
<a href="https://rider.51bike.online" target="_blank">骑手端</a>
</div>
</div>
<div class="footer-copyright">
© 2026 51 | 51bike.online
</div>
</div>
</footer>
</div>
</template>
<script setup>
import { ref, reactive } from 'vue'
const models = [
{
name: '电动自行车',
price: '¥30-50/日',
desc: '轻便灵活适合城市短途配送单次续航60-80公里',
image: 'https://images.unsplash.com/photo-1571068316344-75bc76f77890?w=400&h=300&fit=crop'
},
{
name: '电动摩托车',
price: '¥60-100/日',
desc: '动力充沛适合中距离配送单次续航100-150公里',
image: 'https://images.unsplash.com/photo-1605559424843-9e4c228bf1c2?w=400&h=300&fit=crop'
},
{
name: '电动三轮车',
price: '¥100-180/日',
desc: '载货量大,适合商超配送和外卖聚合配送',
image: 'https://images.unsplash.com/photo-1558618666-fcd25c85cd64?w=400&h=300&fit=crop'
},
{
name: '轻型电动卡车',
price: '¥200-350/日',
desc: '超大载货空间,适合物流最后一公里和批量配送',
image: 'https://images.unsplash.com/photo-1601584115197-04ecc0da31d7?w=400&h=300&fit=crop'
}
]
const stories = [
{
quote: '从每天跑50单到100单我用51租管车更轻松。以前自己修车、找充电桩的时间都省下来了现在只管跑单赚钱。',
author: '张师傅 · 外卖骑手',
avatar: 'https://images.unsplash.com/photo-1560250097-0b93528c311a?w=100&h=100&fit=crop&crop=face'
},
{
quote: '加盟51租做副业租了3辆车给骑手用每月多赚3000多。平台结算快账目清晰比以前轻松多了。',
author: '李老板 · 小型运营商',
avatar: 'https://images.unsplash.com/photo-1472099645785-5658abf4ff4e?w=100&h=100&fit=crop&crop=face'
},
{
quote: '多门店统一管理后调度效率提升了一倍。51租的系统真的很专业订单、车辆、财务一目了然。',
author: '王总 · 连锁运营商',
avatar: 'https://images.unsplash.com/photo-1507003211169-0a1dd7228f2d?w=100&h=100&fit=crop&crop=face'
}
]
const form = reactive({
name: '',
phone: '',
message: ''
})
const handleSubmit = () => {
alert(`感谢您的留言!我们会尽快与您联系。\n\n姓名${form.name}\n电话${form.phone}`)
form.name = ''
form.phone = ''
form.message = ''
}
</script>
<style scoped>
/* 无需额外样式,已在 style.css 中定义 */
</style>

BIN
src/assets/hero.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

1
src/assets/vite.svg Normal file

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 8.5 KiB

1
src/assets/vue.svg Normal file
View File

@ -0,0 +1 @@
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--logos" width="37.07" height="36" preserveAspectRatio="xMidYMid meet" viewBox="0 0 256 198"><path fill="#41B883" d="M204.8 0H256L128 220.8L0 0h97.92L128 51.2L157.44 0h47.36Z"></path><path fill="#41B883" d="m0 0l128 220.8L256 0h-51.2L128 132.48L50.56 0H0Z"></path><path fill="#35495E" d="M50.56 0L128 133.12L204.8 0h-47.36L128 51.2L97.92 0H50.56Z"></path></svg>

After

Width:  |  Height:  |  Size: 496 B

View File

@ -0,0 +1,93 @@
<script setup>
import { ref } from 'vue'
import viteLogo from '../assets/vite.svg'
import heroImg from '../assets/hero.png'
import vueLogo from '../assets/vue.svg'
const count = ref(0)
</script>
<template>
<section id="center">
<div class="hero">
<img :src="heroImg" class="base" width="170" height="179" alt="" />
<img :src="vueLogo" class="framework" alt="Vue logo" />
<img :src="viteLogo" class="vite" alt="Vite logo" />
</div>
<div>
<h1>Get started</h1>
<p>Edit <code>src/App.vue</code> and save to test <code>HMR</code></p>
</div>
<button class="counter" @click="count++">Count is {{ count }}</button>
</section>
<div class="ticks"></div>
<section id="next-steps">
<div id="docs">
<svg class="icon" role="presentation" aria-hidden="true">
<use href="/icons.svg#documentation-icon"></use>
</svg>
<h2>Documentation</h2>
<p>Your questions, answered</p>
<ul>
<li>
<a href="https://vite.dev/" target="_blank">
<img class="logo" :src="viteLogo" alt="" />
Explore Vite
</a>
</li>
<li>
<a href="https://vuejs.org/" target="_blank">
<img class="button-icon" :src="vueLogo" alt="" />
Learn more
</a>
</li>
</ul>
</div>
<div id="social">
<svg class="icon" role="presentation" aria-hidden="true">
<use href="/icons.svg#social-icon"></use>
</svg>
<h2>Connect with us</h2>
<p>Join the Vite community</p>
<ul>
<li>
<a href="https://github.com/vitejs/vite" target="_blank">
<svg class="button-icon" role="presentation" aria-hidden="true">
<use href="/icons.svg#github-icon"></use>
</svg>
GitHub
</a>
</li>
<li>
<a href="https://chat.vite.dev/" target="_blank">
<svg class="button-icon" role="presentation" aria-hidden="true">
<use href="/icons.svg#discord-icon"></use>
</svg>
Discord
</a>
</li>
<li>
<a href="https://x.com/vite_js" target="_blank">
<svg class="button-icon" role="presentation" aria-hidden="true">
<use href="/icons.svg#x-icon"></use>
</svg>
X.com
</a>
</li>
<li>
<a href="https://bsky.app/profile/vite.dev" target="_blank">
<svg class="button-icon" role="presentation" aria-hidden="true">
<use href="/icons.svg#bluesky-icon"></use>
</svg>
Bluesky
</a>
</li>
</ul>
</div>
</section>
<div class="ticks"></div>
<section id="spacer"></section>
</template>

5
src/main.js Normal file
View File

@ -0,0 +1,5 @@
import { createApp } from 'vue'
import './style.css'
import App from './App.vue'
createApp(App).mount('#app')

454
src/style.css Normal file
View File

@ -0,0 +1,454 @@
/* 51租 - 全局样式 */
:root {
--primary: #FF6B00;
--primary-dark: #e55f00;
--white: #FFFFFF;
--gray-light: #F7F7F7;
--gray: #666666;
--gray-dark: #333333;
--shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
--shadow-hover: 0 8px 24px rgba(255, 107, 0, 0.15);
}
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html {
scroll-behavior: smooth;
}
body {
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
color: var(--gray-dark);
background: var(--white);
line-height: 1.6;
}
.container {
max-width: 1200px;
margin: 0 auto;
padding: 0 24px;
}
/* 导航栏 */
.header {
position: fixed;
top: 0;
left: 0;
right: 0;
background: var(--white);
box-shadow: var(--shadow);
z-index: 1000;
height: 64px;
}
.header .container {
display: flex;
align-items: center;
justify-content: space-between;
height: 100%;
}
.logo {
display: flex;
align-items: center;
gap: 8px;
font-size: 24px;
font-weight: bold;
color: var(--primary);
text-decoration: none;
}
.logo-icon {
width: 36px;
height: 36px;
background: var(--primary);
border-radius: 8px;
display: flex;
align-items: center;
justify-content: center;
color: white;
font-size: 18px;
}
.nav {
display: flex;
gap: 32px;
}
.nav a {
color: var(--gray-dark);
text-decoration: none;
font-size: 15px;
transition: color 0.3s;
}
.nav a:hover {
color: var(--primary);
}
@media (max-width: 768px) {
.nav {
display: none;
}
}
/* Hero 区域 */
.hero {
min-height: 100vh;
background: var(--primary);
display: flex;
align-items: center;
padding-top: 64px;
}
.hero-content {
text-align: center;
color: var(--white);
}
.hero h1 {
font-size: 64px;
font-weight: 800;
margin-bottom: 16px;
letter-spacing: -1px;
}
.hero p {
font-size: 22px;
opacity: 0.95;
margin-bottom: 40px;
max-width: 600px;
margin-left: auto;
margin-right: auto;
}
.hero-buttons {
display: flex;
gap: 16px;
justify-content: center;
flex-wrap: wrap;
}
.btn {
display: inline-flex;
align-items: center;
gap: 8px;
padding: 14px 32px;
border-radius: 8px;
font-size: 16px;
font-weight: 600;
text-decoration: none;
transition: all 0.3s;
cursor: pointer;
border: none;
}
.btn-primary {
background: var(--white);
color: var(--primary);
}
.btn-primary:hover {
background: var(--gray-light);
transform: translateY(-2px);
}
.btn-secondary {
background: transparent;
color: var(--white);
border: 2px solid var(--white);
}
.btn-secondary:hover {
background: var(--white);
color: var(--primary);
}
@media (max-width: 768px) {
.hero h1 {
font-size: 40px;
}
.hero p {
font-size: 18px;
}
}
/* 通用区块 */
.section {
padding: 80px 0;
}
.section-gray {
background: var(--gray-light);
}
.section-title {
text-align: center;
margin-bottom: 48px;
}
.section-title h2 {
font-size: 36px;
font-weight: 700;
color: var(--gray-dark);
margin-bottom: 12px;
}
.section-title p {
font-size: 16px;
color: var(--gray);
}
/* 关于我们 */
.about-content {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 48px;
align-items: center;
}
.about-text p {
font-size: 16px;
color: var(--gray);
margin-bottom: 16px;
line-height: 1.8;
}
.about-image img {
width: 100%;
border-radius: 12px;
box-shadow: var(--shadow);
}
@media (max-width: 768px) {
.about-content {
grid-template-columns: 1fr;
}
.about-image {
order: -1;
}
}
/* 车型展示 */
.models-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
gap: 24px;
}
.model-card {
background: var(--white);
border-radius: 12px;
overflow: hidden;
box-shadow: var(--shadow);
transition: all 0.3s;
}
.model-card:hover {
transform: translateY(-4px);
box-shadow: var(--shadow-hover);
}
.model-card img {
width: 100%;
height: 180px;
object-fit: cover;
}
.model-info {
padding: 20px;
}
.model-name {
font-size: 20px;
font-weight: 600;
color: var(--gray-dark);
margin-bottom: 8px;
}
.model-price {
font-size: 18px;
color: var(--primary);
font-weight: 700;
margin-bottom: 8px;
}
.model-desc {
font-size: 14px;
color: var(--gray);
}
/* 用户故事 */
.stories-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 24px;
}
.story-card {
background: var(--white);
border-radius: 12px;
padding: 32px;
box-shadow: var(--shadow);
transition: all 0.3s;
}
.story-card:hover {
transform: translateY(-4px);
box-shadow: var(--shadow-hover);
}
.story-avatar {
width: 64px;
height: 64px;
border-radius: 50%;
object-fit: cover;
margin-bottom: 16px;
}
.story-quote {
font-size: 16px;
color: var(--gray-dark);
line-height: 1.7;
margin-bottom: 16px;
font-style: italic;
}
.story-author {
font-size: 14px;
color: var(--gray);
}
/* 联系我们 */
.contact-content {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 48px;
}
.contact-info {
display: flex;
flex-direction: column;
gap: 24px;
}
.contact-item {
display: flex;
align-items: flex-start;
gap: 16px;
}
.contact-icon {
width: 48px;
height: 48px;
background: var(--primary);
border-radius: 12px;
display: flex;
align-items: center;
justify-content: center;
color: white;
font-size: 20px;
flex-shrink: 0;
}
.contact-text h4 {
font-size: 16px;
font-weight: 600;
color: var(--gray-dark);
margin-bottom: 4px;
}
.contact-text p {
font-size: 14px;
color: var(--gray);
}
.contact-form {
background: var(--white);
padding: 32px;
border-radius: 12px;
box-shadow: var(--shadow);
}
.form-group {
margin-bottom: 20px;
}
.form-group label {
display: block;
font-size: 14px;
font-weight: 500;
color: var(--gray-dark);
margin-bottom: 8px;
}
.form-group input,
.form-group textarea {
width: 100%;
padding: 12px 16px;
border: 1px solid #e0e0e0;
border-radius: 8px;
font-size: 14px;
transition: border-color 0.3s;
}
.form-group input:focus,
.form-group textarea:focus {
outline: none;
border-color: var(--primary);
}
.form-group textarea {
resize: vertical;
min-height: 100px;
}
@media (max-width: 768px) {
.contact-content {
grid-template-columns: 1fr;
}
}
/* Footer */
.footer {
background: var(--gray-dark);
color: var(--white);
padding: 40px 0 20px;
}
.footer-content {
display: flex;
justify-content: space-between;
align-items: center;
flex-wrap: wrap;
gap: 20px;
margin-bottom: 24px;
}
.footer-links {
display: flex;
gap: 24px;
}
.footer-links a {
color: rgba(255, 255, 255, 0.8);
text-decoration: none;
font-size: 14px;
transition: color 0.3s;
}
.footer-links a:hover {
color: var(--primary);
}
.footer-copyright {
font-size: 14px;
color: rgba(255, 255, 255, 0.6);
text-align: center;
padding-top: 20px;
border-top: 1px solid rgba(255, 255, 255, 0.1);
}

7
vite.config.js Normal file
View File

@ -0,0 +1,7 @@
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
// https://vite.dev/config/
export default defineConfig({
plugins: [vue()],
})