96SEO 2026-02-20 01:31 0
各个功能模块如果有过多重复冗杂的部分将会抽取部分值得记录复习的地方进行记录

后端接口http://43.143.0.76:8889/api/private/v1/
‘http://43.143.0.76:8889/api/private/v1/’
配置路由器通过login登录之后会优先跳转到home父组件Element-ui的布局模式redirect重定向路由到welcome欢迎组件
import(/components/Login.vue)},{
import(/components/Home.vue),redirect:
import(/components/Welcome.vue)
import(/components/user/Users.vue)},{
import(/components/power/Rights.vue)},{
import(/components/power/Roles.vue)},{
import(/components/goods/Cate.vue)},{
import(/components/goods/Params.vue)},{
import(/components/goods/List.vue)},{
import(/components/goods/Add.vue)},{
import(/components/order/Order.vue)},{
import(/components/report/Report.vue)}]}]
http是无状态的通过cookie在客户端记录状态通过session在服务器端记录状态通过token方式维持状态
如果前端和后台不存在跨域问题可以通过cookie和session来记录登录状态如果存在跨域问题通过token方式来维持登录状态
如果不通过登录来获取服务器的token值直接通过路由跳转对应页面服务器无法验证token通过有些接口功能将无法实现由此还需要配置路由守卫来防止用户直接通过路由跳转对应页面
就会先返回等到触发的异步操作完成再接着执行函数体内后面的语句。
如果登录成功将服务器的token值保存到客户端的sessionStorage中利用seiItem属性键值对的方法存储以便之后的后续请求都携带token认证
{this.$refs.loginFormRef.validate(async
{this.$message.success(登录成功)//将token值保存到客户端中window.sessionStorage.setItem(token,
res.data.token)//并且跳转路由this.$router.push(/home)}}})},2.3路由守卫
在router.js中配置路由守卫目的是为了防止用户未通过登录而是选择更改路由跳转到对应页面。
next(/login)表示强制跳转到登录页面if(to.path
console.log(to)next()}else{//获取用户当前客户端的token值const
window.sessionStorage.getItem(token)//如果没有token值强制跳转到登录页面//如果存在token就放行if(!tokenStr){next(/login)}else{next()}}})2.4Element-ui的表单验证和表单重置
prefix-iconel-icon-user/el-input/el-form-item!--
prefix-iconel-icon-lock/el-input/el-form-item!--
clicklogin登录/el-buttonel-button
clickreset重置/el-button/el-form-item/el-form//登录时的校验对象loginFormRules:
this指向vue的原型对象通过原型对象绑定对应的resetFields函数
console.log(this)//实现表单的重置功能this.$refs.loginFormRef.resetFields()},2.5退出登录
直接调用sessionStorage.clear()函数清空存储的token即可同时跳转到/login页面即可
{window.sessionStorage.clear()this.$router.push(/login)},3用户管理模块
在回顾具体功能模块前提不得不提一下element-ui的侧边栏组件
:classiconList[item.id]/ispan{{item.authName}}/span/template!--
classel-icon-menu/ispan{{subitem.authName}}/span/el-menu-item/el-submenu/el-menu/el-aside在el-menu标签中:default-active属性值是激活菜单的值并没有设死我们数据绑定到data中的activePath中在el-submenu标签中:index值是通过父级的v-for属性将menuList的所有item通过l插值语法两个花括号显示到模板上需要注意的一点是v-for属性同时需要key属性的同时存在否则会报错
{this.getMenuList()this.activePath
window.sessionStorage.getItem(activePath)},//保存链接的激活状态saveNavState(activePath)
{window.sessionStorage.setItem(activePath,
activePath},savNavState函数解决了图标在当前选项高亮但当重进还是会选择上一高亮位置但内容则是welcome组件内容
通过sessionStorage存储当前的activePath在created()组件被创建的时候再从sessionStorage中取出
//保存链接的激活状态saveNavState(activePath)
{window.sessionStorage.setItem(activePath,
其余的element-ui界面布局组件没什么难度跟着文档走就可以了需要回顾的就是slot-scope作用域插槽
这里是想实现一个按钮来切换状态的效果element-ui提供了这个组件但是我们同时还要实现点击切换状态还要修改数据库中的数据
changeuserStateChange(scope.row)/el-switch/template//监听用户状态修改的事件async
this.$http.put(users/${userInfo.id}/state/${userInfo.mg_state})if
!userInfo.mg_statethis.$message.error(更新用户状态失败)}this.$message.success(更新用户状态成功)},3.3Pagination
current-changehandleCurrentChange
:totaltotal/el-pagination分页功能不仅仅这里需要以后的项目一些业务都是需要分页功能的。
首先需要创建分页数据对象pagenum(当前页数)pagesize(每页显示数据条数)total(总条数)。
将其返回给后端后端返回对应数据。
点击编辑按钮触发点击事件。
展示dialog同时通过id搜索该用户的个人信息将其展现。
用户通过更改本文内容双向数据绑定到editform表单对象中点击取消修改visible属性布尔值来隐藏该对话框点击确定通过请求修改对应数据库中信息同时列表需要刷新再次调用获取用户数据函数也修改visible属性隐藏对话框
disabled/el-input/el-form-item!--
v-modeleditForm.email/el-input/el-form-item!--
v-modeleditForm.mobile/el-input/el-form-item/el-formspan
定/el-button/span/el-dialog编辑按钮结构
clickshowEditDialog(scope.row.id)/el-button点击确定修改信息逻辑
{//预校验this.$refs.editFormRef.validate(async
this.$message.error(更新用户信息失败)}//关闭对话框this.editDialogVisible
false//刷新数据列表this.getUserList()//提示修改成功this.$message.success(更新用户信息成功)})},4权限管理模块
主要还是通过作用域插槽和v-for还有嵌套的权限属性实现当然还有tag标签
el-row标签中利用v-for渲染出父级元素蓝色标签通过作用域插槽传数据同时el-tag将该值渲染成蓝色标签叉叉移除函数,removeRightById由于每个权限都有对应的id所以通过id来删除数据库中数据嵌套
item1.id){{item1.authName}}/el-tagi
classel-icon-caret-right/i/el-col!--
item2.id){{item2.authName}}/el-tagi
classel-icon-caret-right/i/el-colel-col
item3.id){{item3.authName}}/el-tag/el-col/el-row/el-col/el-rowel-row
:span19/el-row/template/el-table-columnremoveRightById()函数
利用了confirm弹窗组件全局挂载promise对象需要.then().catch()来解析发送delete请求的参数利用到了es6模板字符串用法
this.$http.delete(roles/${role.id}/rights/${roleId})if
element-ui提供的级联选择器有时候会出现bugelement-ui的版本不断地更新也在修正
selectedCateKeys数据双向绑定数组change事件当选中节点变化时触发:options绑定商品列表:props绑定对象的某个值实现多级级联选择器
:propscateProps/el-cascader/el-colchange事件函数
{this.getParamsData()},//指定级联选择器的配置对象cateProps:
v-model双向数据绑定对应active选中的数据这里是many和onlytab-click事件监听标签页改变触发
通过级联选择器的handleChange和tabs标签页的handleTabClick两个事件都调用getParamsData()获取商品参数函数通过每个商品的特定id获取对应的参数信息
tab-clickhandleTabClickdata(){//Tabs标签页的双向绑定数据activeName:
}首先级联选择器的长度如果不是3即选中的只是一二级菜单就清空不展示第三级菜单根据所选分类的ID和当前所处的面板获取对应的参数
{//根据所选分类的ID和当前所处的面板获取对应的参数const
this.$http.get(categories/${this.cateId}/attributes,{params:
{this.$message.error(获取参数列表失败)}
console.log(res.data)//存储动态参数数据和静态属性数据res.data.forEach((item)
false)//文本框中输入的值item.inputValue
res.data}}}},将后台返回的数据进行forEach遍历存储还利用了split()分割函数
//存储动态参数数据和静态属性数据res.data.forEach((item)
false)//文本框中输入的值item.inputValue
在商品分类模块中对于分类名称利用到了tree树形控件用清晰的层级结构展示信息可展开或折叠。
:data数据绑定刀catelist商品分类列表。
:columns属性columns纵列分布依旧使用作用域插槽同时利用了v-if来控制对应的显示与隐藏利用表达式的值
clickshowEditDialog(scope.row.cat_id)编辑/el-button!--
clickremoveUserById(scope.row.cat_id)删除/el-button/template/tree-table5.4添加商品信息模块
title完成/el-step/el-steps5.4.2el-tabs左侧标签页
console.log(this.activeIndex)//访问的是商品参数面板if
this.$http.get(categories/${this.cateId}/attributes,{params:
{this.$message.error(获取商品参数失败)}
this.$message.success(成功)this.manyTableData
console.log(this.manyTableDate)}}
this.$http.get(categories/${this.cateId}/attributes,{params:
{this.$message.error(获取商品参数失败)}
console.log(this.onlyTableData)}}},5.4.3upload上传图片
:preview”handlePreview“处理图片预览函数:on-preview“handlePreview”处理图片移除函数
actionhttp://43.143.0.76:8889/api/private/v1/upload
:on-successhandleSuccessel-button
typeprimary点击上传/el-button/el-upload/el-tab-panehandlePreview图片预览函数
console.log(file)this.previewPath
file.response.data.urlthis.previewVisible
file.response.data.tmp_path//2.从pics数组中找到该图片的索引值const
this.addForm.pics.findIndex((x)
filePath})//3.调用数组的splice方法从pics数组中移除this.addForm.pics.splice(i,
echarts.init(this.$refs.main)const
this.$http.get(reports/type/1)if
this.$message.error(初始化折线图失败)const
nprogress/nprogress.css//配置axios请求拦截器
axios.interceptors.request.use(config
{NProgress.start()//为请求头对象添加token验证的Authorization字段config.headers.Authorization
window.sessionStorage.getItem(token)return
axios.interceptors.response.use(config
回想看完成这个项目用自己学的vue的知识一步一步的完成其中有许多相同的部分但还是自己一步一步的完成了期间遇到许许多多的error报错但还是上网不断的搜索搜索debug。
对于路由的掌握更加得心应手了包括登录的token认证路由守卫请求拦截器等等。
但也看过别人的大型项目是将请求同一封装到一个request,js文件中这样的好处更多是避免一个请求的方式出错减少更多的修改以后要还有项目一定尝试尝试。
回想看最头疼的也是最有收获的部分就是分类参数模块的级联选择器配合tabs标签页的使用添加参数等等。
通过这次的整理也算是对vue2的一个整体复习要开始步入vue3和ts的学习了。
作为专业的SEO优化服务提供商,我们致力于通过科学、系统的搜索引擎优化策略,帮助企业在百度、Google等搜索引擎中获得更高的排名和流量。我们的服务涵盖网站结构优化、内容优化、技术SEO和链接建设等多个维度。
| 服务项目 | 基础套餐 | 标准套餐 | 高级定制 |
|---|---|---|---|
| 关键词优化数量 | 10-20个核心词 | 30-50个核心词+长尾词 | 80-150个全方位覆盖 |
| 内容优化 | 基础页面优化 | 全站内容优化+每月5篇原创 | 个性化内容策略+每月15篇原创 |
| 技术SEO | 基本技术检查 | 全面技术优化+移动适配 | 深度技术重构+性能优化 |
| 外链建设 | 每月5-10条 | 每月20-30条高质量外链 | 每月50+条多渠道外链 |
| 数据报告 | 月度基础报告 | 双周详细报告+分析 | 每周深度报告+策略调整 |
| 效果保障 | 3-6个月见效 | 2-4个月见效 | 1-3个月快速见效 |
我们的SEO优化服务遵循科学严谨的流程,确保每一步都基于数据分析和行业最佳实践:
全面检测网站技术问题、内容质量、竞争对手情况,制定个性化优化方案。
基于用户搜索意图和商业目标,制定全面的关键词矩阵和布局策略。
解决网站技术问题,优化网站结构,提升页面速度和移动端体验。
创作高质量原创内容,优化现有页面,建立内容更新机制。
获取高质量外部链接,建立品牌在线影响力,提升网站权威度。
持续监控排名、流量和转化数据,根据效果调整优化策略。
基于我们服务的客户数据统计,平均优化效果如下:
我们坚信,真正的SEO优化不仅仅是追求排名,而是通过提供优质内容、优化用户体验、建立网站权威,最终实现可持续的业务增长。我们的目标是与客户建立长期合作关系,共同成长。
Demand feedback