当前位置:首页 > Web开发 > 正文

Nuxt目录结构详解、Nuxt常用配置项、Nuxt路由配置和参数传递

2024-03-31 Web开发

[TOC]

1、Nuxt目录结构详解

Nuxt项目文件目录结构

|-- .nuxt // Nuxt自动生成,临时的用于编辑的文件,build |-- assets // 用于组织未编译的静态资源入LESS、SASS 或 JavaScript |-- components // 用于自己编写的Vue组件,比如滚动组件,日历组件,分页组件 |-- layouts // 布局目录,用于组织应用的布局组件,不可更改。 |-- middleware // 用于存放中间件 |-- pages // 用于存放写的页面,我们主要的工作区域 |-- plugins // 用于存放JavaScript插件的地方 |-- static // 用于存放静态资源文件,比如图片 |-- store // 用于组织应用的Vuex 状态管理。 |-- .editorconfig // 开发工具格式配置 |-- .eslintrc.js // ESLint的配置文件,用于检查代码格式 |-- .gitignore // 配置git不上传的文件 |-- nuxt.config.json // 用于组织Nuxt.js应用的个性化配置,已覆盖默认配置 |-- package-lock.json // npm自动生成,用于帮助package的统一性设置的,yarn也有相同的操作 |-- package-lock.json // npm自动生成,用于帮助package的统一性设置的,yarn也有相同的操作 |-- package.json // npm包管理配置文件 2、Nuxt常用配置项 配置IP和端口

开发中经常会遇到端口被占用或者指定IP的情况。我们需要在根目录下的package.json里对config项进行配置。比如现在我们想把IP配置成127.0.0.1,端口设置1818。

/package.json

"config":{ "nuxt":{ "host":"127.0.0.1", "port":"1818" } },

配置全局CSS

在开发多页项目时,都会定义一个全局的CSS来初始化我们的页面渲染,比如把padding和margin设置成0,非常出名的开源css文件normailze.css

使用命令安装npm install normalize.css。

全局配置,需要在nuxt.config.js里进行操作

/assets/fontcolor.css

html{ color:red; }

/nuxt.config.js

css:[`~assets/fontcolor.css`]

pages里新建一个页面,随便写点东西,路径不用配置Nuxt.js配好了

全局配置生效

配置webpack的loader

在nuxt.config.js里是可以对webpack的基本配置进行覆盖的,比如现在我们要配置一个url-loader来进行小图片的64为打包。就可以在nuxt.config.js的build选项里进行配置。

首先安装url-loader

npm install --save-dev url-loader build: { loaders:[ { test:/\.(png|jpe?g|gif|svg)$/, loader:"url-loader", query:{ limit:10000, name:‘img/[name].[hash].[ext]‘ } } ], /* ** Run ESLint on save */ extend (config, { isDev, isClient }) { if (isDev && isClient) { config.module.rules.push({ enforce: ‘pre‘, test: /\.(js|vue)$/, loader: ‘eslint-loader‘, exclude: /(node_modules)/ }) } } }

什么是Webpack

WebPack可以看做是模块打包机:简单说就是,分析你的项目结构,找到例如JavaScript以及其它的一些浏览器不能直接运行的拓展语言,,将其转换和打包为合适的格式供浏览器使用。

loader:是webpack用来预处理模块的,在一个模块被引入之前,会预先使用loader处理模块的内容。默认webpack只会处理js代码,所以当我们想要区打包其他内容时,让webpack处理其他类型的内容,就要使用相应的loader

3、Nuxt的路由配置和参数传递 3.1、Nuxt路由配置

路由就是我们的跳转机制,可以理解为链接跳转,体现我们的业务逻辑,把模块串联起来,Nuxt.js的路由,它给我们进行了封装,让我们节省了很多配置环节。

在根目录的pages文件下新建两个文件夹,用于测试

about/index.vue

<template> <div> <h2>About Index page</h2> <ul> <li> <nuxt-link to="http://www.mamicode.com/">Home</nuxt-link> </li> </ul> </div> </template> <script> export default {}; </script> <style> </style>

温馨提示: 本文由Jm博客推荐,转载请保留链接: https://www.jmwww.net/file/web/40314.html