使用Nuxt.js实现服务端渲染(SSR):提升SEO与性能的完整指南

使用Nuxt.js实现服务端渲染(SSR):提升SEO与性能的完整指南

  • 使用Nuxt.js实现服务端渲染(SSR):提升SEO与性能的完整指南
    • 1. 服务端渲染(SSR)核心概念
      • 1.1 CSR vs SSR vs SSG
      • 1.2 SSR工作原理图解
    • 2. Nuxt.js框架深度解析
      • 2.1 Nuxt.js架构设计
        • 2.1.1 约定优于配置(Convention Over Configuration)
        • 2.1.2 分层架构设计
      • 2.2 核心特性全解
        • 2.2.1 自动路由系统
        • 2.2.2 多渲染模式支持
      • 2.3 模块系统与插件机制
        • 2.3.1 官方模块生态系统
        • 2.3.2 自定义插件开发
      • 2.4 配置体系详解
        • 2.4.1 核心配置项解析
        • 2.4.2 环境变量管理
      • 2.5 生命周期全流程解析
        • 2.5.1 服务端生命周期
        • 2.5.2 客户端Hydration流程
      • 2.6 数据获取策略对比
        • 2.6.1 asyncData vs fetch
        • 2.6.2 数据缓存策略
      • 2.7 状态管理进阶实践
        • 2.7.1 Vuex模块化架构
        • 2.7.2 服务端数据预取
      • 2.8 错误处理与调试技巧
        • 2.8.1 自定义错误页面
        • 2.8.2 性能调试工具
      • 2.9 进阶开发技巧
        • 2.9.1 动态布局切换
        • 2.9.2 混合渲染模式
      • 2.10 版本升级指南(Nuxt 2 → Nuxt 3)
        • 2.10.1 主要变化点
        • 2.10.2 迁移策略
    • 3. 实战:构建Nuxt.js SSR应用
      • 3.1 项目初始化
      • 3.2 动态路由示例
    • 4. SEO优化实践
      • 4.1 智能元数据管理
        • 4.1.1 基础元数据配置
        • 4.1.2 动态元数据注入
        • 4.1.3 高级元数据管理
      • 4.2 结构化数据集成
        • 4.2.1 Schema.org 结构化标记
        • 4.2.2 面包屑导航实现
      • 4.3 预渲染策略优化
        • 4.3.1 静态生成配置
        • 4.3.2 混合渲染模式
      • 4.4 社交媒体优化
        • 4.4.1 Open Graph 协议
        • 4.4.2 Twitter Cards 配置
      • 4.5 国际SEO优化
        • 4.5.1 多语言配置
        • 4.5.2 hreflang 实现
      • 4.6 内容优化策略
        • 4.6.1 语义化HTML结构
        • 4.6.2 内部链接优化
      • 4.7 性能优化与SEO
        • 4.7.1 关键资源预加载
        • 4.7.2 图片优化方案
      • 4.8 SEO监控与分析
        • 4.8.1 Google Search Console集成
        • 4.8.2 SEO健康检查清单
      • 4.9 常见SEO问题解决方案
        • 4.9.1 重复内容处理
        • 4.9.2 分页优化
      • 4.10 持续SEO优化策略
        • 4.10.1 内容更新机制
        • 4.10.2 性能持续监控
    • 5. 性能优化方案
      • 5.1 组件级缓存
    • 6. 部署配置示例
      • 6.1 PM2生产配置
    • 总结:

使用Nuxt.js实现服务端渲染(SSR):提升SEO与性能的完整指南

1. 服务端渲染(SSR)核心概念

1.1 CSR vs SSR vs SSG

通过对比表格展示不同渲染方式的差异:

特性CSRSSRSSG
渲染时机客户端服务端构建时
SEO支持度优秀优秀
首屏加载速度极快
适用场景后台系统内容型网站静态内容网站

1.2 SSR工作原理图解

User Browser Server API 访问URL 发送页面请求 请求初始数据 返回数据 渲染HTML 返回完整HTML 执行Hydration User Browser Server API

以下是 “2. Nuxt.js框架深度解析” 的详细扩展内容,约5000字:


2. Nuxt.js框架深度解析

2.1 Nuxt.js架构设计

2.1.1 约定优于配置(Convention Over Configuration)

Nuxt.js 采用"约定优于配置"的设计理念,通过标准化目录结构降低决策成本:

├── assets/       # 未编译资源
├── components/   # 可复用组件
├── layouts/      # 布局模板
├── pages/        # 自动生成路由
├── plugins/      # 第三方插件
├── static/       # 直接访问的静态文件
└── store/        # Vuex状态管理

这种设计使得开发者无需手动配置路由和构建流程,专注于业务逻辑开发。对于需要自定义的场景,可通过 nuxt.config.js 进行覆盖。

2.1.2 分层架构设计

Nuxt.js 采用三层架构模型:

  1. 服务层:处理Node.js服务端逻辑
  2. 渲染层:实现Vue组件到HTML的转换
  3. 客户端层:管理浏览器端Hydration

这种分层设计使得SSR过程对开发者透明,同时保持框架的可扩展性。


2.2 核心特性全解

2.2.1 自动路由系统

Nuxt.js 根据 pages 目录结构自动生成路由配置:

pages/
├── index.vue        => /
└── users/├── index.vue    => /users└── _id.vue      => /users/:id

支持动态路由、嵌套路由和自定义路由配置:

// nuxt.config.js
export default {router: {extendRoutes(routes, resolve) {routes.push({path: '/custom',component: resolve(__dirname, 'pages/custom-page.vue')})}}
}
2.2.2 多渲染模式支持

Nuxt.js 提供三种渲染模式:

// nuxt.config.js
export default {ssr: true,  // 服务端渲染模式(SSR)target: 'server' // 或 'static'(静态生成)
}
  1. Universal Mode (SSR)
  2. Static Site Generation (SSG)
  3. Single Page Application (SPA)

模式对比:

特性SSR模式SSG模式SPA模式
首屏加载速度极快
动态内容支持优秀需客户端hydrate完全动态
部署复杂度需要Node服务器纯静态托管纯静态托管

2.3 模块系统与插件机制

2.3.1 官方模块生态系统

Nuxt.js 通过模块系统扩展功能:

// nuxt.config.js
export default {modules: ['@nuxtjs/axios','@nuxtjs/auth-next','@nuxtjs/sitemap']
}

常用官方模块:

  • @nuxtjs/axios:封装HTTP请求
  • @nuxtjs/pwa:PWA支持
  • @nuxt/content:内容管理系统
2.3.2 自定义插件开发

插件注入示例:

// plugins/hello.js
export default ({ app }, inject) => {inject('hello', (msg) => console.log(`Hello ${msg}!`))
}// nuxt.config.js
export default {plugins: ['~/plugins/hello.js']
}// 组件内使用
this.$hello('World') // 控制台输出 "Hello World!"

2.4 配置体系详解

2.4.1 核心配置项解析
// nuxt.config.js
export default {// 构建配置build: {transpile: ['lodash-es'],extend(config, { isClient }) {if (isClient) {config.optimization.splitChunks.maxSize = 250000}}},// 环境变量publicRuntimeConfig: {API_BASE_URL: process.env.API_BASE_URL || 'https://api.example.com'},// 渲染配置render: {compressor: { threshold: 0 },etag: { weak: true }}
}
2.4.2 环境变量管理

推荐使用 .env 文件:

# .env
API_SECRET=your_api_secret
BASE_URL=https://production.com

配置读取策略:

// nuxt.config.js
export default {publicRuntimeConfig: {baseURL: process.env.BASE_URL},privateRuntimeConfig: {apiSecret: process.env.API_SECRET}
}

2.5 生命周期全流程解析

2.5.1 服务端生命周期
Client Server Store Middleware Page 页面请求 执行服务端中间件 提交数据到Vuex 触发asyncData/fetch 返回渲染完成的HTML Client Server Store Middleware Page
2.5.2 客户端Hydration流程
// 完整生命周期顺序:
1. nuxtServerInit (store)
2. middleware- 全局中间件- 布局中间件- 路由中间件
3. validate()
4. asyncData()
5. fetch()
6. head()
7. 客户端mounted()

2.6 数据获取策略对比

2.6.1 asyncData vs fetch
<script>
export default {async asyncData({ $axios }) {const posts = await $axios.$get('/api/posts')return { posts }},fetch({ store }) {return store.dispatch('loadUserData')}
}
</script>

特性对比:

方法执行环境访问组件实例数据合并方式
asyncData仅服务端直接合并到data
fetch双端需手动提交store
2.6.2 数据缓存策略
// 使用lru-cache实现接口级缓存
const LRU = require('lru-cache')
const cache = new LRU({ max: 1000 })export default function ({ $axios }) {$axios.onRequest((config) => {if (config.cacheKey && cache.has(config.cacheKey)) {return Promise.resolve(cache.get(config.cacheKey))}return config})
}

2.7 状态管理进阶实践

2.7.1 Vuex模块化架构
// store/user.js
export const state = () => ({profile: null
})export const mutations = {SET_PROFILE(state, profile) {state.profile = profile}
}export const actions = {async loadProfile({ commit }) {const profile = await this.$axios.$get('/api/profile')commit('SET_PROFILE', profile)}
}
2.7.2 服务端数据预取
// 使用nuxtServerInit预取全局数据
export const actions = {nuxtServerInit({ dispatch }, { req }) {if (req.headers.cookie) {return dispatch('user/loadFromCookie', req.headers.cookie)}}
}

2.8 错误处理与调试技巧

2.8.1 自定义错误页面
<!-- layouts/error.vue -->
<template><div class="error-container"><h1>{{ error.statusCode }}</h1><p>{{ error.message }}</p><button @click="$router.push('/')">返回首页</button></div>
</template><script>
export default {props: ['error']
}
</script>
2.8.2 性能调试工具
  1. 使用 nuxt-bundle-analyzer 分析构建体积
  2. 通过 $nuxt.context 查看运行时上下文
  3. 集成Sentry进行错误监控:
// nuxt.config.js
export default {buildModules: ['@nuxtjs/sentry'],sentry: {dsn: process.env.SENTRY_DSN,config: {}}
}

2.9 进阶开发技巧

2.9.1 动态布局切换
<script>
export default {layout(context) {return context.isMobile ? 'mobile' : 'default'}
}
</script>
2.9.2 混合渲染模式
// nuxt.config.js
export default {render: {static: {paths: ['/static-page']},ssr: {paths: ['/dynamic/*']}}
}

2.10 版本升级指南(Nuxt 2 → Nuxt 3)

2.10.1 主要变化点
  1. 基于Vue 3的Composition API
  2. Nitro服务引擎替换
  3. 模块系统重构
  4. TypeScript原生支持
2.10.2 迁移策略
  1. 逐步替换Options API为Composition API
  2. 使用 @nuxt/bridge 过渡
  3. 重构自定义模块
  4. 更新部署配置

3. 实战:构建Nuxt.js SSR应用

3.1 项目初始化

npx create-nuxt-app my-ssr-project

3.2 动态路由示例

// pages/articles/_id.vue
export default {async asyncData({ params }) {const article = await fetch(`/api/articles/${params.id}`)return { article }},head() {return {title: this.article.title,meta: [{ hid: 'description', name: 'description', content: this.article.excerpt }]}}
}

4. SEO优化实践

4.1 智能元数据管理

4.1.1 基础元数据配置

Nuxt.js 提供全局和组件级的元数据管理能力:

// nuxt.config.js
export default {head: {title: '默认标题',titleTemplate: '%s | 网站品牌',htmlAttrs: { lang: 'zh-CN' },meta: [{ charset: 'utf-8' },{ name: 'viewport', content: 'width=device-width, initial-scale=1' },{ hid: 'description', name: 'description', content: '默认描述' },{ hid: 'keywords', name: 'keywords', content: '默认关键词' }],link: [{ rel: 'icon', type: 'image/x-icon', href: '/favicon.ico' }]}
}
4.1.2 动态元数据注入

在页面组件中覆盖全局配置:

<script>
export default {head() {return {title: this.product.name,meta: [{ hid: 'description', name: 'description', content: this.product.summary },{ hid: 'og:image', property: 'og:image', content: this.product.coverImage },{ name: 'robots', content: this.indexable ? 'index,follow' : 'noindex,nofollow' }]}}
}
</script>
4.1.3 高级元数据管理

使用 @nuxtjs/robots 模块管理爬虫指令:

npm install @nuxtjs/robots
// nuxt.config.js
export default {modules: ['@nuxtjs/robots'],robots: {UserAgent: '*',Disallow: ['/admin', '/private'],Sitemap: process.env.BASE_URL + '/sitemap.xml'}
}

4.2 结构化数据集成

4.2.1 Schema.org 结构化标记
<script>
export default {jsonld() {return {'@context': 'https://schema.org','@type': 'Product',name: this.product.name,image: this.product.images,offers: {'@type': 'Offer',priceCurrency: 'CNY',price: this.product.price}}}
}
</script>
4.2.2 面包屑导航实现
<script>
export default {jsonld() {return {'@context': 'https://schema.org','@type': 'BreadcrumbList',itemListElement: [{'@type': 'ListItem',position: 1,name: '首页',item: process.env.BASE_URL},{'@type': 'ListItem',position: 2,name: this.category.name,item: `${process.env.BASE_URL}/categories/${this.category.slug}`}]}}
}
</script>

4.3 预渲染策略优化

4.3.1 静态生成配置
// nuxt.config.js
export default {target: 'static',generate: {routes: ['/products/1','/products/2',async () => {const products = await fetch('https://api.example.com/products')return products.map(product => `/products/${product.id}`)}],fallback: '404.html'}
}
4.3.2 混合渲染模式
// nuxt.config.js
export default {render: {static: true,ssr: true,hybrid: {routes: {'/dynamic/*': 'ssr','/static/*': 'static'}}}
}

4.4 社交媒体优化

4.4.1 Open Graph 协议
<script>
export default {head() {return {meta: [{ property: 'og:type', content: 'article' },{ property: 'og:url', content: `${process.env.BASE_URL}${this.$route.path}` },{ property: 'og:title', content: this.article.title },{ property: 'og:description', content: this.article.excerpt },{ property: 'og:image', content: this.article.coverImage },{ property: 'og:site_name', content: '网站名称' }]}}
}
</script>
4.4.2 Twitter Cards 配置
<script>
export default {head() {return {meta: [{ name: 'twitter:card', content: 'summary_large_image' },{ name: 'twitter:site', content: '@yourtwitterhandle' },{ name: 'twitter:creator', content: '@authorhandle' }]}}
}
</script>

4.5 国际SEO优化

4.5.1 多语言配置
// nuxt.config.js
export default {modules: ['nuxt-i18n'],i18n: {locales: [{ code: 'en', iso: 'en-US', file: 'en-US.js' },{ code: 'zh', iso: 'zh-CN', file: 'zh-CN.js' }],defaultLocale: 'zh',strategy: 'prefix_except_default',detectBrowserLanguage: false}
}
4.5.2 hreflang 实现
<script>
export default {head() {const links = []this.$i18n.locales.forEach(locale => {links.push({hid: `alternate-hreflang-${locale.code}`,rel: 'alternate',hreflang: locale.iso,href: `${process.env.BASE_URL}${this.$i18n.getPath(locale.code, this.$route.path)}`})})return { link: links }}
}
</script>

4.6 内容优化策略

4.6.1 语义化HTML结构
<template><article><header><h1>{{ article.title }}</h1><time :datetime="article.publishedAt">{{ formatDate(article.publishedAt) }}</time></header><section><nuxt-content :document="article" /></section><footer><author-info :author="article.author" /></footer></article>
</template>
4.6.2 内部链接优化
<template><div class="related-articles"><h2>相关文章</h2><ul><li v-for="article in relatedArticles" :key="article.id"><nuxt-link :to="`/articles/${article.slug}`">{{ article.title }}</nuxt-link></li></ul></div>
</template>

4.7 性能优化与SEO

4.7.1 关键资源预加载
// nuxt.config.js
export default {render: {resourceHints: true,http2: {push: true,pushAssets: (req, res, publicPath, preloadFiles) => {return preloadFiles.filter(f => f.asType === 'script' && f.file === 'runtime.js').map(f => `<${publicPath}${f.file}>; rel=preload; as=${f.asType}`)}}}
}
4.7.2 图片优化方案
<template><picture><source :srcset="require(`~/assets/images/${imageName}?webp`)" type="image/webp"><img :src="require(`~/assets/images/${imageName}`)" :alt="altText"loading="lazy"width="800"height="600"></picture>
</template>

4.8 SEO监控与分析

4.8.1 Google Search Console集成
<!-- layouts/default.vue -->
<script>
export default {head() {return {script: [{hid: 'google-site-verification',src: `https://www.googletagmanager.com/gtag/js?id=${process.env.GA_TRACKING_ID}`,async: true},{hid: 'gtm-init',innerHTML: `window.dataLayer = window.dataLayer || [];function gtag(){dataLayer.push(arguments);}gtag('js', new Date());gtag('config', '${process.env.GA_TRACKING_ID}');`,type: 'text/javascript'}]}}
}
</script>
4.8.2 SEO健康检查清单
  1. 使用 Screaming Frog 抓取全站
  2. 验证所有页面的HTTP状态码
  3. 检查是否有重复的元描述和标题(建议不超过3次)
  4. 分析外链质量(使用Ahrefs或Majestic)
  5. 移动端友好性测试(Google Mobile-Friendly Test)
  6. 核心Web指标达标检测(Lighthouse)

4.9 常见SEO问题解决方案

4.9.1 重复内容处理
// nuxt.config.js
export default {modules: ['@nuxtjs/robots'],robots: {rules: {UserAgent: '*',Disallow: ['/search*','/?ref=*']}}
}
4.9.2 分页优化
<script>
export default {head() {const canonical = `${process.env.BASE_URL}${this.$route.path}`const prev = this.currentPage > 1 ? `${canonical}?page=${this.currentPage - 1}`: nullconst next = this.currentPage < this.totalPages ? `${canonical}?page=${this.currentPage + 1}`: nullreturn {link: [{ rel: 'canonical', href: canonical },...(prev ? [{ rel: 'prev', href: prev }] : []),...(next ? [{ rel: 'next', href: next }] : [])]}}
}
</script>

4.10 持续SEO优化策略

4.10.1 内容更新机制
// 自动生成sitemap
const createSitemapRoutes = async () => {const { $content } = require('@nuxt/content')const articles = await $content('articles').fetch()return articles.map(article => `/articles/${article.slug}`)
}export default {sitemap: {hostname: process.env.BASE_URL,routes: createSitemapRoutes,defaults: {changefreq: 'weekly',priority: 0.8}}
}
4.10.2 性能持续监控
// 集成Web Vitals监控
export default function ({ app }) {app.router.afterEach((to, from) => {if (typeof window !== 'undefined' && window.gtag) {setTimeout(() => {import('web-vitals').then(({ getCLS, getFID, getLCP }) => {getCLS(console.log)getFID(console.log)getLCP(console.log)})}, 3000)}})
}

5. 性能优化方案

5.1 组件级缓存

// nuxt.config.js
export default {render: {bundleRenderer: {cache: require('lru-cache')({max: 1000,maxAge: 1000 * 60 * 15})}}
}

6. 部署配置示例

6.1 PM2生产配置

// ecosystem.config.js
module.exports = {apps: [{name: 'my-nuxt-app',exec_mode: 'cluster',instances: 'max',script: './node_modules/nuxt/bin/nuxt.js',args: 'start'}]
}

总结:

本文深入解析了如何通过Nuxt.js实现服务端渲染(SSR)以全面提升SEO与性能。Nuxt.js通过自动路由生成、混合渲染模式(SSR/SSG)和智能数据预取,显著优化首屏加载速度与搜索引擎友好性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/67995.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

解释 Java 中的反射机制和动态代理的原理?

反射机制是Java语言的一个特性&#xff0c;它允许程序在运行时检查和操作类、方法、字段等。 通过反射&#xff0c;我们可以在运行时获取类的信息&#xff0c;创建对象&#xff0c;调用方法和访问字段&#xff0c;即使这些信息在编译时是未知的。 反射的基本用法 import jav…

http状态码:504 Gateway Timeout(网关超时)的原有以及排查问题的思路

504 Gateway Timeout&#xff08;网关超时&#xff09; 是一种常见的HTTP错误状态码&#xff0c;表示服务器作为网关或代理时&#xff0c;未能及时从上游服务器收到响应。以下是它的原因和排查问题的思路&#xff1a; 1. 504错误的含义 定义&#xff1a;服务器作为网关或代理时…

Linux 安装 RabbitMQ

Linux下安装RabbitMQ 1 、获取安装包 # 地址 https://github.com/rabbitmq/erlang-rpm/releases/download/v21.3.8.9/erlang-21.3.8.9-1.el7.x86_64.rpm erlang-21.3.8.9-1.el7.x86_64.rpmsocat-1.7.3.2-1.el6.lux.x86_64.rpm# 地址 https://github.com/rabbitmq/rabbitmq-se…

LOCAL_PREBUILT_JNI_LIBS使用说明

LOCAL_PREBUILT_JNI_LIBS使用说明 使用LOCAL_PREBUILT_JNI_LIBS&#xff0c;可用于控制APK集成时&#xff0c;其相关so的集成方式。 比如&#xff0c;用于将APK中的so&#xff0c;抽取出来。 LOCAL_PREBUILT_JNI_LIBS : \lib/arm64-v8a/libNativeCore.so \lib/arm64-v8a/liba…

Java中的object类

1.Object类是什么&#xff1f; &#x1f7ea;Object 是 Java 类库中的一个特殊类&#xff0c;也是所有类的父类(超类),位于类继承层次结构的顶端。也就是说&#xff0c;Java 允许把任何类型的对象赋给 Object 类型的变量。 &#x1f7e6;Java里面除了Object类&#xff0c;所有的…

uniapp小程序自定义中间凸起样式底部tabbar

我自己写的自定义的tabbar效果图 废话少说咱们直接上代码&#xff0c;一步一步来 第一步&#xff1a; 找到根目录下的 pages.json 文件&#xff0c;在 tabBar 中把 custom 设置为 true&#xff0c;默认值是 false。list 中设置自定义的相关信息&#xff0c; pagePath&#x…

四、GPIO中断实现按键功能

4.1 GPIO简介 输入输出&#xff08;I/O&#xff09;是一个非常重要的概念。I/O泛指所有类型的输入输出端口&#xff0c;包括单向的端口如逻辑门电路的输入输出管脚和双向的GPIO端口。而GPIO&#xff08;General-Purpose Input/Output&#xff09;则是一个常见的术语&#xff0c…

vscode+CMake+Debug实现 及权限不足等诸多问题汇总

环境说明 有空再补充 直接贴两个json tasks.json {"version": "2.0.0","tasks": [{"label": "cmake","type": "shell","command": "cmake","args": ["../"…

【Elasticsearch】post_filter

post_filter是 Elasticsearch 中的一种后置过滤机制&#xff0c;用于在查询执行完成后对结果进行过滤。以下是关于post_filter的详细介绍&#xff1a; 工作原理 • 查询后过滤&#xff1a;post_filter在查询执行完毕后对返回的文档集进行过滤。这意味着所有与查询匹配的文档都…

《数据可视化新高度:Graphy的AI协作变革》

在数据洪流奔涌的时代&#xff0c;企业面临的挑战不再仅仅是数据的收集&#xff0c;更在于如何高效地将数据转化为洞察&#xff0c;助力决策。Graphy作为一款前沿的数据可视化工具&#xff0c;凭借AI赋能的团队协作功能&#xff0c;为企业打开了数据协作新局面&#xff0c;重新…

Vue 2 与 Vue 3 的主要区别

Vue.js 是一个流行的前端框架&#xff0c;用于构建用户界面和单页应用。自从 Vue 2 发布以来&#xff0c;社区对其进行了广泛的应用和扩展&#xff0c;而 Vue 3 的发布则带来了许多重要的改进和新特性。 性能提升 Vue 3 在响应式系统上进行了重大的改进&#xff0c;采用了基于…

从零开始:用Qt开发一个功能强大的文本编辑器——WPS项目全解析

文章目录 引言项目功能介绍1. **文件操作**2. **文本编辑功能**3. **撤销与重做**4. **剪切、复制与粘贴**5. **文本查找与替换**6. **打印功能**7. **打印预览**8. **设置字体颜色**9. **设置字号**10. **设置字体**11. **左对齐**12. **右对齐**13. **居中对齐**14. **两侧对…

【IoCDI】_Spring的基本扫描机制

目录 1. 创建测试项目 2. 改变启动类所属包 3. 使用ComponentScan 4. Spring基本扫描机制 程序通过注解告诉Spring希望哪些bean被管理&#xff0c;但在仅使用Bean时已经发现&#xff0c;Spring需要根据五大类注解才能进一步扫描方法注解。 由此可见&#xff0c;Spring对注…

vue 引入百度地图和高德天气 都得获取权限

vue接入百度地图---获取ak https://blog.csdn.net/qq_57144407/article/details/143430661 vue接入高德天气&#xff0c; 需要授权----获取key https://www.jianshu.com/p/09ddd698eebe

通向AGI之路:人工通用智能的技术演进与人类未来

文章目录 引言:当机器开始思考一、AGI的本质定义与技术演进1.1 从专用到通用:智能形态的范式转移1.2 AGI发展路线图二、突破AGI的五大技术路径2.1 神经符号整合(Neuro-Symbolic AI)2.2 世界模型架构(World Models)2.3 具身认知理论(Embodied Cognition)三、AGI安全:价…

python中的命名规范

在python中&#xff0c;命名规范是编写清晰&#xff0c;可读性强代码的重要部分&#xff0c;遵循这些规范可以使代码更易于理解和维护。 Type命名约定命名例子函数&#xff08;Function&#xff09;小写单词&#xff0c;下划线分割单词function,delta_function方法&#xff08…

【工具变量】中国省级八批自由贸易试验区设立及自贸区设立数据(2024-2009年)

一、测算方式&#xff1a;参考C刊《中国软科学》任晓怡老师&#xff08;2022&#xff09;的做法&#xff0c;使用自由贸易试验区(Treat Post) 表征&#xff0c;Treat为个体不随时间变化的虚拟变量&#xff0c;如果该城市设立自由贸易试验区则赋值为1&#xff0c;反之赋值为0&am…

Java进阶总结——集合

Java进阶总结——集合 说明&#xff1a;对于以上的框架图有如下几点说明 1.所有集合类都位于java.util包下。Java的集合类主要由两个接口派生而出&#xff1a;Collection和Map&#xff0c;Collection和Map是Java集合框架的根接口&#xff0c;这两个接口又包含了一些子接口或实…

计算机视觉和图像处理

计算机视觉与图像处理的最新进展 随着人工智能技术的飞速发展&#xff0c;计算机视觉和图像处理作为其中的重要分支&#xff0c;正逐步成为推动科技进步和产业升级的关键力量。 一、计算机视觉的最新进展 计算机视觉&#xff0c;作为人工智能的重要分支&#xff0c;主要研究如…

3.PPT:华老师-计算机基础课程【3】

目录 NO12​ NO34​ NO56​ NO789​ NO12 根据考生文件夹下的Word文档“PPT素材.docx”中提供的内容在PPT.pptx中生成初始的6张幻灯片 新建幻灯片6张→ctrlc复制→ctrlv粘贴开始→新建幻灯片→幻灯片(从大纲)→Word文档注❗前提是&#xff1a;Word文档必须应用标题1、标题2…