2026-01-18 12:21:49 +08:00
|
|
|
|
<template>
|
|
|
|
|
|
<div class="bigfe-demo">
|
2026-02-14 12:14:07 +08:00
|
|
|
|
<div class="demo-header">
|
|
|
|
|
|
<span class="icon">🌐</span>
|
|
|
|
|
|
<span class="title">前端 vs 大前端</span>
|
|
|
|
|
|
<span class="subtitle">了解不同平台的运行环境和技术栈</span>
|
2026-01-18 12:21:49 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
|
2026-02-14 12:14:07 +08:00
|
|
|
|
<div class="demo-content">
|
|
|
|
|
|
<div class="platforms">
|
|
|
|
|
|
<button
|
|
|
|
|
|
v-for="p in platforms"
|
|
|
|
|
|
:key="p.key"
|
|
|
|
|
|
class="platform"
|
|
|
|
|
|
:class="{ active: current === p.key }"
|
|
|
|
|
|
@click="current = p.key"
|
|
|
|
|
|
>
|
|
|
|
|
|
<span class="icon">{{ p.icon }}</span>
|
|
|
|
|
|
<span>{{ p.label }}</span>
|
|
|
|
|
|
</button>
|
2026-01-18 12:21:49 +08:00
|
|
|
|
</div>
|
2026-02-14 12:14:07 +08:00
|
|
|
|
|
|
|
|
|
|
<div class="cards">
|
|
|
|
|
|
<div class="card">
|
|
|
|
|
|
<div class="label">运行环境</div>
|
|
|
|
|
|
<div class="value">{{ currentData.runtime }}</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="card">
|
|
|
|
|
|
<div class="label">主要技术</div>
|
|
|
|
|
|
<div class="value">{{ currentData.stack }}</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="card">
|
|
|
|
|
|
<div class="label">发布方式</div>
|
|
|
|
|
|
<div class="value">{{ currentData.release }}</div>
|
|
|
|
|
|
</div>
|
2026-01-18 12:21:49 +08:00
|
|
|
|
</div>
|
2026-02-14 12:14:07 +08:00
|
|
|
|
|
|
|
|
|
|
<div class="skills">
|
|
|
|
|
|
<div class="skills-title">哪些能力是"共通的"?</div>
|
|
|
|
|
|
<div class="tags">
|
|
|
|
|
|
<span v-for="t in commonSkills.slice(0, 6)" :key="t" class="tag">{{ t }}</span>
|
|
|
|
|
|
</div>
|
2026-01-18 12:21:49 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
2026-02-14 12:14:07 +08:00
|
|
|
|
<div class="info-box">
|
|
|
|
|
|
<span class="icon">💡</span>
|
|
|
|
|
|
<strong>核心思想:</strong>大前端不是"会更多框架",而是用同一套工程能力,把体验交付到不同平台。
|
2026-01-18 12:21:49 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script setup>
|
|
|
|
|
|
import { ref, computed } from 'vue'
|
|
|
|
|
|
|
|
|
|
|
|
const platforms = [
|
2026-02-14 12:14:07 +08:00
|
|
|
|
{ key: 'web', label: 'Web网站', icon: '🌐' },
|
|
|
|
|
|
{ key: 'h5', label: 'H5活动页', icon: '📱' },
|
2026-01-18 12:21:49 +08:00
|
|
|
|
{ key: 'miniapp', label: '小程序', icon: '🧩' },
|
2026-02-14 12:14:07 +08:00
|
|
|
|
{ key: 'native', label: '原生App', icon: '📲' },
|
|
|
|
|
|
{ key: 'cross', label: '跨端App', icon: '🧱' },
|
2026-01-18 12:21:49 +08:00
|
|
|
|
{ key: 'desktop', label: '桌面应用', icon: '🖥️' }
|
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
const current = ref('web')
|
|
|
|
|
|
|
|
|
|
|
|
const data = {
|
|
|
|
|
|
web: {
|
|
|
|
|
|
runtime: '浏览器 (Chrome/Safari/Edge)',
|
|
|
|
|
|
stack: 'HTML + CSS + JavaScript / Vue / React',
|
|
|
|
|
|
release: '部署到服务器/静态托管,用户刷新即可更新'
|
|
|
|
|
|
},
|
|
|
|
|
|
h5: {
|
|
|
|
|
|
runtime: '手机浏览器 / App 内的 WebView',
|
|
|
|
|
|
stack: '同 Web,但更关注性能与兼容',
|
|
|
|
|
|
release: '发链接/扫码即用,迭代很快'
|
|
|
|
|
|
},
|
|
|
|
|
|
miniapp: {
|
|
|
|
|
|
runtime: '小程序运行时(微信/支付宝等)',
|
|
|
|
|
|
stack: '小程序框架 + JS/TS + 组件',
|
|
|
|
|
|
release: '需要审核/发布(比网页慢一些)'
|
|
|
|
|
|
},
|
|
|
|
|
|
native: {
|
|
|
|
|
|
runtime: 'iOS/Android 原生系统',
|
|
|
|
|
|
stack: 'Swift/Objective-C / Kotlin/Java',
|
|
|
|
|
|
release: '应用商店上架(流程最慢,但能力最强)'
|
|
|
|
|
|
},
|
|
|
|
|
|
cross: {
|
|
|
|
|
|
runtime: '原生壳 + 跨端引擎',
|
|
|
|
|
|
stack: 'React Native / Flutter(用一套代码做多端)',
|
|
|
|
|
|
release: '仍走商店流程,但研发复用更高'
|
|
|
|
|
|
},
|
|
|
|
|
|
desktop: {
|
|
|
|
|
|
runtime: 'Windows/macOS/Linux',
|
|
|
|
|
|
stack: 'Electron / Tauri(用 Web 技术做桌面)',
|
|
|
|
|
|
release: '打包成安装包/自动更新'
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const currentData = computed(() => data[current.value] || data.web)
|
|
|
|
|
|
|
|
|
|
|
|
const commonSkills = [
|
|
|
|
|
|
'HTTP/网络',
|
|
|
|
|
|
'性能优化',
|
|
|
|
|
|
'工程化与构建',
|
|
|
|
|
|
'组件化',
|
|
|
|
|
|
'状态管理',
|
|
|
|
|
|
'调试与排错',
|
|
|
|
|
|
'用户体验'
|
|
|
|
|
|
]
|
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
|
.bigfe-demo {
|
|
|
|
|
|
border: 1px solid var(--vp-c-divider);
|
2026-02-14 12:14:07 +08:00
|
|
|
|
border-radius: 8px;
|
2026-01-18 12:21:49 +08:00
|
|
|
|
background: var(--vp-c-bg-soft);
|
2026-02-14 12:14:07 +08:00
|
|
|
|
padding: 1rem;
|
|
|
|
|
|
margin: 1rem 0;
|
|
|
|
|
|
max-height: 600px;
|
|
|
|
|
|
overflow-y: auto;
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 12:14:07 +08:00
|
|
|
|
.demo-header {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
gap: 0.5rem;
|
|
|
|
|
|
margin-bottom: 0.75rem;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.demo-header .icon {
|
|
|
|
|
|
font-size: 1.25rem;
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 12:14:07 +08:00
|
|
|
|
.demo-header .title {
|
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
|
font-size: 1rem;
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 12:14:07 +08:00
|
|
|
|
.demo-header .subtitle {
|
2026-01-18 12:21:49 +08:00
|
|
|
|
color: var(--vp-c-text-2);
|
2026-02-14 12:14:07 +08:00
|
|
|
|
font-size: 0.85rem;
|
|
|
|
|
|
margin-left: 0.5rem;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.demo-content {
|
|
|
|
|
|
margin-bottom: 0.5rem;
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.platforms {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
flex-wrap: wrap;
|
|
|
|
|
|
gap: 0.5rem;
|
2026-02-14 12:14:07 +08:00
|
|
|
|
margin-bottom: 1rem;
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.platform {
|
|
|
|
|
|
border: 1px solid var(--vp-c-divider);
|
|
|
|
|
|
background: var(--vp-c-bg);
|
|
|
|
|
|
padding: 0.45rem 0.75rem;
|
|
|
|
|
|
border-radius: 999px;
|
|
|
|
|
|
font-size: 0.85rem;
|
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
|
display: inline-flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
gap: 0.35rem;
|
2026-02-14 12:14:07 +08:00
|
|
|
|
transition: all 0.2s;
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 12:14:07 +08:00
|
|
|
|
.platform:hover {
|
|
|
|
|
|
background: var(--vp-c-bg-soft);
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 12:14:07 +08:00
|
|
|
|
.platform.active {
|
|
|
|
|
|
border-color: var(--vp-c-brand);
|
|
|
|
|
|
color: var(--vp-c-brand);
|
|
|
|
|
|
background: var(--vp-c-brand-soft);
|
|
|
|
|
|
font-weight: 600;
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.cards {
|
|
|
|
|
|
display: grid;
|
|
|
|
|
|
grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
|
|
|
|
|
|
gap: 0.75rem;
|
2026-02-14 12:14:07 +08:00
|
|
|
|
margin-bottom: 1rem;
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.card {
|
|
|
|
|
|
border: 1px solid var(--vp-c-divider);
|
|
|
|
|
|
background: var(--vp-c-bg);
|
|
|
|
|
|
border-radius: 10px;
|
|
|
|
|
|
padding: 0.85rem;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.label {
|
|
|
|
|
|
font-size: 0.85rem;
|
|
|
|
|
|
color: var(--vp-c-text-2);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.value {
|
|
|
|
|
|
margin-top: 0.25rem;
|
|
|
|
|
|
font-size: 0.95rem;
|
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
|
line-height: 1.35;
|
2026-02-14 12:14:07 +08:00
|
|
|
|
color: var(--vp-c-text-1);
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.skills {
|
|
|
|
|
|
border-top: 1px dashed var(--vp-c-divider);
|
2026-02-14 12:14:07 +08:00
|
|
|
|
padding-top: 0.75rem;
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.skills-title {
|
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
|
margin-bottom: 0.5rem;
|
2026-02-14 12:14:07 +08:00
|
|
|
|
font-size: 0.9rem;
|
|
|
|
|
|
color: var(--vp-c-text-1);
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.tags {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
flex-wrap: wrap;
|
|
|
|
|
|
gap: 0.45rem;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.tag {
|
|
|
|
|
|
font-size: 0.8rem;
|
|
|
|
|
|
padding: 0.2rem 0.55rem;
|
|
|
|
|
|
border-radius: 999px;
|
2026-02-14 12:14:07 +08:00
|
|
|
|
background: var(--vp-c-bg-alt);
|
|
|
|
|
|
color: var(--vp-c-text-1);
|
|
|
|
|
|
border: 1px solid var(--vp-c-divider);
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 12:14:07 +08:00
|
|
|
|
.info-box {
|
|
|
|
|
|
background: var(--vp-c-bg-alt);
|
|
|
|
|
|
padding: 0.75rem;
|
|
|
|
|
|
border-radius: 6px;
|
2026-01-18 12:21:49 +08:00
|
|
|
|
font-size: 0.85rem;
|
|
|
|
|
|
color: var(--vp-c-text-2);
|
2026-02-14 12:14:07 +08:00
|
|
|
|
display: flex;
|
|
|
|
|
|
gap: 0.25rem;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.info-box .icon {
|
|
|
|
|
|
flex-shrink: 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.info-box strong {
|
|
|
|
|
|
color: var(--vp-c-text-1);
|
2026-01-18 12:21:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
</style>
|