- 添加Docker相关配置文件(.dockerignore, .env.example, .gitignore) - 实现服务端API代理功能,支持文件、模块和服务器API转发 - 创建文章详情页、栏目文章列表页和单页内容展示页面 - 集成Ant Design Vue组件库并实现SSR样式提取功能 - 定义API响应数据结构类型和应用布局组件 - 开发开发者应用中心和文章管理页面 - 实现CMS导航菜单获取和多租户切换功能
38 lines
789 B
TypeScript
38 lines
789 B
TypeScript
import { useHead, useRequestURL, useSeoMeta } from '#app'
|
|
|
|
type SeoInput = {
|
|
title: string
|
|
description: string
|
|
path?: string
|
|
}
|
|
|
|
function getSiteOrigin() {
|
|
if (import.meta.client) return window.location.origin
|
|
try {
|
|
return useRequestURL().origin
|
|
} catch {
|
|
return ''
|
|
}
|
|
}
|
|
|
|
export function usePageSeo(input: SeoInput) {
|
|
const origin = getSiteOrigin()
|
|
const url = input.path && origin ? new URL(input.path, origin).toString() : undefined
|
|
|
|
useSeoMeta({
|
|
title: input.title,
|
|
description: input.description,
|
|
ogTitle: input.title,
|
|
ogDescription: input.description,
|
|
ogType: 'website',
|
|
...(url ? { ogUrl: url } : {}),
|
|
twitterCard: 'summary_large_image'
|
|
})
|
|
|
|
if (url) {
|
|
useHead({
|
|
link: [{ rel: 'canonical', href: url }]
|
|
})
|
|
}
|
|
}
|