前端Vue项目经验汇总

前端Vue项目经验汇总

页面显示

头部左右两边可以通过slot卡槽去处理
前端Vue项目经验汇总
底部导航显示与否可以通过路由里面的meta属性进行配置
前端Vue项目经验汇总

前端Vue项目经验汇总
返回上一级页面
$router.back()
$router:路由器对象,包含一些操作路由的功能函数,来实现编程式导航(路由跳转)
$route:当前路由对象,一些当前路由信息数据的容器,path/meta/query/params

异步请求数据

vue异步请求数据详细介绍
axios请求数据封装

/*
    	封装请求函数
    	返回值:promise对象
    */
    import axios from 'axios'
    let ajax = (url,data = {},type = 'GET') => {
    	return new Promise((resolve,reject) => {
    		let promise;
    		if(type == 'GET'){
    			let dataString = '';
    			Object.keys(data).forEach((key)=>{//组装url后面拼接的请求参数
    				dataString += `&${key}=${data[key]}`
    			})
    			if(dataString != ''){
    				dataString = dataString.substring(0,dataString.lastIndexOf('&'))
    				url = url + '?' +dataString
    			}
    			promise = axios.get(url)
    		}else{
    			promise = axios.post(url,data)
    		}
    		promise.then((response)=>{
    			resolve(response.data)
    		}).catch((err)=>{
    			reject(err)
    		})
    	})
    }
    export default ajax;

接口封装

/*
接口封装
*/
import ajax from './ajax.js'
const baseUrl = '/api'
export const getCategory = () => ajax(baseUrl + '/index_category')

组件中调用

import {getCategory} from './api/index.js'
async mounted(){
    const result = await getCategory()
    console.log(result)
}

跨域请求
上面请求数据可能涉及到跨域,两种解决方法,1、后台配置跨域,2、配置代理蒙骗浏览器config–>index.js

//配置代理
proxyTable: {
     '/api':{
         target:'http://localhost:4000/',
         changeOrigin:true,
         pathRewrite:{
             '/api':''
         }
     }
 }

Vuex状态管理

页面上调用actions方法,促使mutations去改变state中的数据

动态获取数据之后swiper轮播图无法滑动
swiper初始的时候是静态资源,请求数据的时候页面还没有更新,资源没有配置好。两种解决方法:
1.将swiper的配置文件放到updated中即可,页面更新之后再去配置

mounted(){
	this.$store.dispatch('getCategory') 
},
updated(){
	new Swiper('.swiper-container',{
	    loop: true, // 循环模式选项
	    // 如果需要分页器
	    pagination: {
	        el: '.swiper-pagination',
	    }
    })
}

2.采用$nextTick,获取数据之后,页面跟新立即调用

watch:{
	category(val){
		this.$nextTick(()=>{//this.$nextTick()将回调延迟到下次DOM更新循环之后执行。在修改数据之后立即使用它,然后等待 DOM 更新。
			new Swiper('.swiper-container',{
			    loop: true, // 循环模式选项
			    // 如果需要分页器
			    pagination: {
			        el: '.swiper-pagination',
			    }
	    	})
		})
	}
}

数据绑定

已绑定数据新增属性问题
对于已经声明绑定了的数据,在新增属性的时候,如果直接使用obj.a去新增,数据可以增加,但是无法绑定显示到页面上。
需要通过Vue.set方法来处理,传3个参数
Vue.set(绑定对象,新增属性,属性值)

路由

缓存路由组件对象

<keep-alive>
  <router-view/>
</keep-alive>

复用路由组件对象,复用路由组件获取的后台数据
通过replace属性解决路由回退问题

<router-link to="/shop/shopgoods" replace>点餐</router-link>

默认路由添加方式为push,这样就会导致点击页面回退的时候不能直接回退到跳进时的页面,可以使用replace属性来解决这一问题
路由组件懒加载
打包好的Vue项目,JS文件包含所有项目的内容,我们在进入页面的时候只需要加载当前页面路由的js即可,不需要把所有直接加载出来,在路由文件中修改引入配置,用函数的方式来实现,进入路由的时候再去引用相应的文件。

/*
import Msite from '@/pages/Msite/Msite.vue'
import Search from '@/pages/Search/Search.vue'
import Order from '@/pages/Order/Order.vue'
import Profile from '@/pages/Profile/Profile.vue'
*/
//路由组件懒加载
const Msite = () => import('@/pages/Msite/Msite.vue')
const Search = () => import('@/pages/Search/Search.vue')
const Order = () => import('@/pages/Order/Order.vue')
const Profile = () => import('@/pages/Profile/Profile.vue')

前端Vue项目经验汇总这样一来,不同路由模块会产生不同的JS文件,在点击路由之后引入对应的即可

打包文件分析与优化

打包可视化
npm run build --report
前端Vue项目经验汇总可视化页面中模块所占页面的大小就是打包之后文件所占内存的大小,对于一些占比过大的部分就需要进行优化了。

打包出错

报错1:
ERROR in static/js/vendor.xxxxx.js from UglifyJs
原由:
脚手架安装项目
修改了npm install下载插件的代码,babel无法解析
在build/webpack.base.conf.js添加需要被再次解析的文件

{
   test: /\.js$/,
   loader: 'babel-loader',
   include: [resolve('src'), resolve('test'), resolve('node_modules/vue-echarts'),resolve('node_modules/vue2-or
  • 4
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你想进行VUE项目实战并开发一个VUE后台管理系统,以下是一些建议和资源可供参考。 首先,如果你是大学即将毕业或自学前端且缺乏项目经验,你可以考虑以下几点: - 寻找相关的在线教程或课程,这些资源通常会提供详细的步骤和案例来帮助你实践VUE项目。你可以搜索一些知名的在线教育平台,如网易云课堂、慕课网等。 - 参考md文档,一些教程可能会总结在md文档中,这将帮助你更好地理解项目开发过程中的每一步。 - 观看相关的视频教程,比如在哔哔哩哩上搜索"程序员Allen",他提供了一些关于VUE项目实战的视频教程。 另外,如果你想开发一个基于VUE的后台管理系统,你需要考虑以下几点: - 确定使用的技术栈。目前最新的技术栈中,Vue3.2、TypeScript、Vite3、Pinia、Element-Plus是一些常见的选择。这些技术将帮助你更高效地开发后台管理系统。 - 寻找开源的后台管理框架。你可以搜索一些开源的后台管理框架,这些框架提供了一些常用的组件、Hooks、指令、动态路由、按钮级别权限控制等功能。这将节省你的开发时间和提高效率。 总之,为了进行VUE项目实战和开发后台管理系统,你可以参考在线教程、学习md文档、观看相关视频教程,同时寻找开源的后台管理框架来加速你的开发过程。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Vue项目实战 —— 后台管理系统( pc端 ) —— Pro最终版本](https://blog.csdn.net/m0_57904695/article/details/129730440)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [Vue项目实战 —— 后台管理系统( pc端 )](https://blog.csdn.net/m0_67391377/article/details/124818830)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值