IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> nuxt.js项目从创建到上线学习笔记 -> 正文阅读

[JavaScript知识库]nuxt.js项目从创建到上线学习笔记

nuxt.js项目创建到上线笔记

项目起步

  1. npm create nuxt-app <项目名>
  2. 选择配置如下:(此配置安装elementUI和axios)
    在这里插入图片描述
  3. 启动项目:npm run dev

一、生命周期

三大类:
服务端生命周期
nuxtServerInit、middleware、validate、asyncData
服务端和客户端共同有的生命周期
created、fetch
客户端生命周期
mounted...

注意:服务端生命周中没有window等

二、nuxtjs请求接口

1 .请求接口使用asyncData这个生命周期

  • asyncData中没有this,需要return返回数据
  • 只能再pages文件夹中的.vue文件使用生效

2. fetch

  • 也可以请求接口,但是接口数据渲染到页面上,有时候有,有时候没有。
  • 内部可以写this
  • fetch生命周期,在任何.vue文件中都可以

三、 如何设置代理

  1. 下载proxy
	npm install @nuxtjs/proxy -S
  1. 在nuxt.config.js中进行配置
	axios:{
  	//是否开启跨域
    	proxy:true
 	},
  	proxy:{
    	'/api':{
      		target:'http://.......cn/'
    	}
  	},
  	modules: [
	    '@nuxtjs/proxy',
	],

四、 axios二次封装,api解耦

下载axios

npm install @nuxtjs/axios -S
  1. 在nuxt.config.js中引入
modules: [
   '@nuxtjs/proxy',
   '@nuxtjs/axios'
   ],

1. api解耦

  1. 配置: nuxt.config.js
plugins: [
  '~/plugins/axios',
   '~/api/xxx.js'
],
  1. xxx.js中写入:
export default ({$axios},inject)=>{
   	inject('getFirstCategorys',()=>$axios({
   		url:'/api/course/category/getFirstCategorys',
           method:'GET',
   	}))

   }

2.axios二次封装

// 二次封装axios
export default ({$axios})=>{

//请求拦截器
   $axios.onRequest((config)=>{
   	console.log(11);
     	return config;
   })

   //响应拦截器
   $axios.onResponse((response)=>{
   	console.log(222);
       return response.data;
   })

}
  1. 页面或者组件请求
async asyncData( app ){
	 let res = await app.$getFirstCategorys();
	    return {
	    	list:res.data.list
		}
	}

五、路由

1.nuxtjs会自动生成路由

2. 用原来项目中的router/index.js

  1. 下载
npm install @nuxtjs/router -S
  1. 在nuxt.config.js配置
modules:[
		'@nuxtjs/router'
	]
  1. 把vue-cli中的router文件拷贝到nuxt项目根目录
  2. 修改最后返回(注意导出为函数)
export function createRouter(){
	return new Router({
	      mode: "history",
	      routes,
	    });
	}

3.页面如何跳转

template:
	<router-link to='/my'>跳转</router-link>
  	<nuxt-link to='/my'>跳转</nuxt-link>
js:和vue2一样 

4.导航守卫

六、组件传值

vue2怎么写,nuxtjs就怎么写

七、状态管理store

vue2怎么写,nuxtjs就怎么写

注意store的返回不同,返回的是函数,这一点和router有点像

	import Vue from 'vue';
	import Vuex from 'vuex';

	Vue.use(Vuex);

	const state = {
		str:'这是store的数据'
	}

	//====== 开始

	const store = ()=> new Vuex.Store({
	  	state
	});

	export default store;

	//====== 结束

八、项目上线

1.首先执行npm run build
2.

将打包好的	
.nuxt
static
nuxt.config.js
package.json
这四个文件丢到服务器的某个文件夹中,在服务器上安装node环境
  1. 在服务器上面执行npm install
  2. 在服务器上面执行npm run start
  3. 使用nginx做代理,想项目域名代理到localhost:3000上面就阔以用域名直接访问项目了
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-24 18:03:56  更:2022-05-24 18:05:46 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 9:04:52-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码