Nuxt3学习总结(05)

nuxt.config.ts 配置详解

nuxt.config.ts 文件中常见配置选项:

import type { NuxtConfig } from 'nuxt';

const config: NuxtConfig = {
  // 全局页面标题: https://go.nuxtjs.dev/config-head
  head: {
    title: 'My App',
    meta: [
      { charset: 'utf-8' },
      { name: 'viewport', content: 'width=device-width, initial-scale=1' },
      { hid: 'description', name: 'description', content: '' }
    ],
    link: [
      { rel: 'icon', type: 'image/x-icon', href: '/favicon.ico' }
    ]
  },

  // 全局 CSS: https://go.nuxtjs.dev/config-css
  css: [],

  // 页面装载之前的插件: https://go.nuxtjs.dev/config-plugins
  plugins: [],

  // 自动导入组件: https://go.nuxtjs.dev/config-components
  components: true,

  // 开发和构建的模块 (推荐): https://go.nuxtjs.dev/config-modules
  buildModules: [],

  // 模块: https://go.nuxtjs.dev/config-modules
  modules: [],

  // 构建配置: https://go.nuxtjs.dev/config-build
  build: {},

  // 服务器配置: https://nuxtjs.org/docs/3.x/features/nuxt-server#configure-http-server
  server: {
    port: 3000, // 默认: 3000
    host: '0.0.0.0' // 默认: localhost
  }
}

export default config;
  • head:该属性用于配置应用程序的 HTML 标头。在此处可以定义标题、元标记和链接到外部文件(例如样式表和 favicon)。

  • css:该属性用于定义应该包含在应用程序中的 CSS 文件。

  • plugins:该属性用于定义应包含在应用程序中的插件。

  • components:该属性设置是否应自动从 components/ 目录中导入组件。

  • buildModules:该属性用于定义应在构建过程中使用的模块(例如 @nuxt/typescript-build@nuxtjs/tailwindcss)。

  • modules:该属性用于定义应导入到应用程序中的模块。

  • build:该属性用于配置应用程序的构建过程。您可以通过定义选项来自定义构建过程,例如输出目录、用于块和文件的文件名以及要使用的插件。

  • server:该属性用于配置 HTTP 服务器。您可以定义服务器应监听的端口和主机。

Nuxt 只认 nuxt.config.ts,因此一些大家熟悉的独立配置文件会被忽略,作为替代,nuxt.config.ts 中会有对应的配置项,如 postcss、vite、webpack.

app.config.ts 配置详解

app.config配置文件公开应用程序中的响应性配置,能够在生命周期内的运行时更新它,或者使用nuxt插件并使用HMR(热模块替换)编辑它。

export default defineAppConfig({
  accessKey: 'key'
})

不能把一些涉密的值放在app.config文件,可以使用.evn这样的配置文件配置环境变量,将覆盖app.config配置文件中的配置

app.config.ts 中配置

   // 只能用于服务端的 keys
    apiKey: 'test',
    // 可用于客户端的 keys
    public: {
      apiBase: '/api'
    }

.evn文件,需要加NUXT_前缀,且需要转为大写

NUXT_API_KEY=api_token
NUXT_PUBLIC_API_BASE=https://test.com
端口号配置
{
  "scripts": {
    "dev": "nuxt dev --port=8080"
  }
}
useHead

Nuxt 提供了一个 useHead() 可以在组件内修改 meta 信息

<script setup lang="ts">
useHead({
  title: 'My App',
  meta: [
    { name: 'description', content: 'My site.' },
    { name: 'keywords', content: 'nuxt、nuxt3、vue' }
  ],
  bodyAttrs: {
    test: 'test'
  },
  script: [ { children: 'console.log('Hello world')' } ]
})
</script>

可在每个页面单独设置信息

useHead({
  title: '文章详情'
})

可以设置标题模板

<script setup lang="ts">
useHead({
  titleTemplate: (title) => {
    return title ? `${title} - 我的网站` : "我的网站";
  },
});
</script>

这样子页面如果设置了title,就能拼接上该模板,一起展示。

Nuxt 还提供了多种组件可以在模板中设置具体页面页头信息:

<Title>, <Base>, <NoScript>, <Style>, <Meta>, <Link>, <Body>, <Html> , <Head>
### 回答1: Vue SSR(Server Side Rendering)服务端渲染是一种在服务器端将Vue组件渲染成HTML字符串的技术。Vue SSR可以提高应用程序的性能和搜索引擎优化。在此基础上,Nuxt.js是一个基于Vue.js的通用应用框架,它通过一个命令行工具来创建和管理Vue SSR应用程序。Nuxt.js提供了一些默认的配置,使得创建Vue SSR应用程序变得非常简单。 CNode社区是一个专门讨论Node.js技术的社区,许多Node.js开发者都会在这里交流。在本文中,我们将使用Nuxt.js来创建一个CNode社区的SSR应用程序。我们将使用CNode社区提供的API来获取帖子列表,然后使用Nuxt.js来将其渲染成HTML字符串,最后将其呈现给用户。 首先,我们需要安装Nuxt.js和一些必要的依赖项。可以使用以下命令来安装: ``` npm install --save nuxt axios ``` 接下来,我们需要配置Nuxt.js。我们可以在项目的根目录中创建一个`nuxt.config.js`文件来配置Nuxt.js。我们需要配置Nuxt.js的一些选项,例如页面路由、构建选项、插件等等。以下是一个简单的配置示例: ```javascript module.exports = { head: { title: 'CNode社区', meta: [ { charset: 'utf-8' }, { name: 'viewport', content: 'width=device-width, initial-scale=1' }, ], }, modules: ['@nuxtjs/axios'], axios: { baseURL: 'https://cnodejs.org/api/v1', }, plugins: ['~/plugins/vue-markdown.js'], }; ``` 在上面的配置中,我们设置了页面标题,设置了meta标签,使用了`@nuxtjs/axios`模块来发送HTTP请求,设置了API的基本URL,以及添加了一个Vue插件来渲染Markdown。 接下来,我们需要创建页面。在Nuxt.js中,每个`.vue`文件都可以作为一个页面,它们位于`pages`目录中。我们可以创建一个名为`index.vue`的文件来显示CNode社区的帖子列表。以下是`index.vue`的示例代码: ```html <template> <div> <h1>CNode社区</h1> <ul> <li v-for="post in posts" :key="post.id"> <router-link :to="'/post/' + post.id">{{ post.title }}</router-link> </li> </ul> </div> </template> <script> export default { asyncData({ $axios }) { return $axios.get('/topics').then((res) => { return { posts: res.data.data }; }); }, }; </script> ``` 在上面的代码中,我们使用了Vue.js的`v-for`指令来遍历每个帖子,并使用Vue.js的`router-link`组件来呈现帖子标题和链接。我们还使用了Nuxt.js提供的`asyncData`方法来在服务器端获取帖子列表。在这个方法中,我们使用了`$axios`模块来发送HTTP请求,获取帖子列表数据,并将其存储在`posts`变量中。 最后,我们需要启动应用程序。可以使用以下命令来启动: ``` npm run dev ``` 这将启动一个本地服务器,可以在浏览器中访问`http://localhost:3000`来查看我们的应用程序。 总结一下,通过Nuxt.js和Vue SSR技术,我们可以快速创建一个CNode社区帖子列表的SSR应用程序。我们只需要简单地配置Nuxt.js,然后创建一个`.vue`文件作为页面,并使用`asyncData`方法来获取数据和渲染页面。 ### 回答2: Vue SSR服务端渲染是指在服务端将Vue组件渲染为HTML,然后将其发送给浏览器进行展示。这种技术的好处是可以提高页面的渲染速度和SEO友好性。 Nuxt.js是一个基于Vue.js的服务端渲染应用框架,它提供了很多方便的特性和工具,可以帮助我们快速开发和部署Vue SSR应用。 CNode社区是一个以Node.js为后端,Vue.js为前端的技术社区。我们可以使用Nuxt.js来打造CNode社区的SSR应用,从而提升用户体验和搜索引擎的收录。 首先,我们可以使用Nuxt.js的CLI工具来初始化一个新的项目,选择SSR模式。然后,我们可以根据CNode社区的需求,创建相应的页面组件,如首页、帖子详情页、用户个人中心等。 在创建这些页面组件的过程中,我们可以使用Nuxt.js提供的一些特性,如动态路由、全局组件等,来简化开发和提升复用性。 在每个页面组件中,我们可以通过asyncData方法来获取数据,并将其作为组件的属性进行渲染。这样,我们就可以在服务端获取数据并渲染好HTML,然后将其发送到浏览器进行展示。 为了提高页面的加载速度,我们可以使用Nuxt.js的代码拆分功能,将不同页面的代码拆分成多个小块,并按需加载。这样,用户只需要加载当前页面所需的代码,可以减少页面的加载时间。 最后,我们可以使用Nuxt.js的部署工具来快速部署CNode社区的SSR应用。Nuxt.js支持将应用打包成静态文件,并可以轻松地部署到各种服务器或服务商上。 总结来说,通过深入学习Vue SSR服务端渲染,借助Nuxt.js框架,我们可以有效地打造CNode社区的SSR应用,提升用户体验和搜索引擎的收录,从而更好地为用户提供技术交流和资源分享的平台。 ### 回答3: Vue SSR(服务端渲染)是一种将Vue应用程序在服务器端进行渲染的技术。通过使用服务器端渲染,可以将静态HTML页面返回给客户端浏览器,从而提高首次加载速度和搜索引擎的抓取能力。而Nuxt.js是一个基于Vue SSR的框架,提供了一整套开箱即用的功能以快速构建Vue SSR应用程序。 在使用Nuxt.js构建CNode社区时,我们可以深入学习Vue SSR服务端渲染的原理和技巧。首先,我们需要了解Nuxt.js提供的目录结构和配置文件,这些会帮助我们更好地组织和管理前端开发流程。接下来,我们需要学习如何使用Nuxt.js的路由系统和异步数据获取功能,这些能帮助我们实现动态的页面渲染和数据预取。 在深入学习Vue SSR服务端渲染时,我们还需要了解服务器端渲染的优势和限制。通过SSR,我们可以提供更好的搜索引擎优化和用户体验,但也需要注意应用程序中可能出现的问题,比如对于某些浏览器不支持的特性、第三方库的兼容性和性能方面的考虑等。 除此之外,为了更好地打造CNode社区,我们还需要学习如何使用Nuxt.js的插件系统和组件库,以及如何与后端API进行交互和数据处理。通过深入学习Vue SSR服务端渲染和使用Nuxt.js打造CNode社区,我们可以提升自己的前端开发技能,并且能够快速构建出高效、可扩展的Vue SSR应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叶落风尘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值