基于vue-admin-element开发后台管理系统【技术点整理】

news2025/1/10 12:13:09

一、Vue点击跳转外部链接

点击重新打开一个页面窗口,不覆盖当前的页面

 window.open('https://www.baidu.com',"_blank")
 "_blank"  新打开一个窗口
 "_self"    覆盖当前的窗口

例如:导入用户模板下载

templateDownload() {
	window.open('https:网址', "_self")
},

二、js 循环修改数组属性key值

思路:建一个空数组,进行push

let arrayNew = [];
datas.map((item, index) => {
	arryNew.push(Object.assign({}, item, {
		name: item.myName,
		value:item
	}));
	return arrayNew;
});
this.List = arrayNew;

三、vue中el-cascader(级联选择器) 根据下拉数据的id获取所对应的文字

<template>
	<div class="app-container">
		<el-cascader  style="width: 280px;" 
		ref="cascader" 
		v-model="select_address" 
		:props="props"
		placeholder="选择地区" 
		:options="address_options"
		@change="select_addressFun" 
		clearable />	
	</div>
</template>

<script>
	import { Address } from '@/api/user'   //封装的获取省市区的接口
	export default {
		data() {
			return {
				props: {
					value: "Code",
					label: "Name"
				},
				address_options: [],
				select_address: '',
			}
		},
		created() {
			this.getAddress()   //调用省市区接口
		},
		methods: {
			// 获取省市区
			getAddress() {
				Address().then(res => {
					console.log(res)
					this.address_options = this.getTrees(res.DataList, '');
					console.log('省市区', this.address_options)
				})
			},
			getTrees(ary, pid) {
				if (!pid) {
					// 如果没有父id(第一次递归的时候)将所有父级查询出来
					return ary.filter(item => item.Level == 1).map(item => {
						// 通过父节点ID查询所有子节点
						item.children = this.getTrees(ary, item.Code)
						return item
					})
				} else {
					return ary.filter(item => item.FatherCode === pid).map(item => {
						// 通过父节点ID查询所有子节点
						if (this.getTrees(ary, item.Code).length > 0) {
							item.children = this.getTrees(ary, item.Code)
						}
						return item
					})
				}
			},
			//筛选省市区-删除选中状态
			reset() {
				this.select_address = []; //v-model绑定值清空
				this.$nextTick(() => {
					// 清空级联选择器选中状态
					this.$refs.cascader.$refs.panel.clearCheckedNodes()
					// 清除⾼亮
					this.$refs.cascader.$refs.panel.activePath = []
				})
			},

			//筛选省市区
			select_addressFun(value) {
				console.log("筛选省市区", value)
				// this.listQuery.PCode = value[0]
				// this.listQuery.CityCode = value[1]
				this.listQuery.ParamCode = value[2] || '' //行政区划代码
				// 获取节点下的汉字 (主要代码)
				let data = this.$refs.cascader.getCheckedNodes()[0].pathLabels.toString()
				//用for循环遍历获取的数据,并把逗号裁掉
				for (let i = 0; i < data.length; i++) {
					if (data[i] === ',') {
						data = data.replace(data[i], '')
					}
				}
				console.log('获取节点下的汉字', data);
				// this.temp.ProvinceCode = value[0]
				// this.temp.CityCode = value[1]
				// this.temp.AreaCode = value[2]
				// this.temp.OrgAddress = data
			},

		}
	}
</script>

四、el-cascader (级联选择器 )可以单独选择任意一级选项

在第三个问题的代码上进行添加:

	<el-cascader  style="width: 280px;" 
		ref="cascader" 
		v-model="select_address" 
		:props="props"
		placeholder="选择地区" 
		:options="address_options"
		@change="select_addressFun" 
		clearable />

	data() {
		return {
			props: {
				value: "Code",
				label: "Name",
				checkStrictly:true   //关键代码:设置父子节点取消选中关联,可以选择任意一级选项
			},
		}
	}

在这里插入图片描述

五、vue 实现手机号中间四位隐藏,显示*号


const tel = '15611116666'        //获取到接口返回的手机号
this.userTel= tel.replace(/(\d{3})\d{4}(\d{4})/, '$1****$2');

六、el-input 限制只能输入数字


<el-input  
 v-model="myDayNum"
 oninput="value=value.replace(/^\.+|[^\d.]/g,'')"    //关键代码
 placeholder="输入次数" />
 

七、vue实现导出excel 功能

通过vue实现导出有2种方式:
(1)后端返回的是一个地址,直接拼接打开下载即可。
(2)后端返回的是文件流的形式,这个时候就需要在 请求头和返回值 这两处设置一下。

1.后端返回的是地址

// 页面代码
<el-button
    type="primary"
    size="mini"
    class="filter-item"
    icon="el-icon-download"
    @click="exportFun">
       导出
 </el-button>
 
 exportFun() { //导出方法
     ExpUserList(this.listQuery)  //导出接口
      .then(result => {
         const url = result.data
         window.open(url)    //通过这个打开网页就可下载导出
      })
      .catch(err => console.log(err))
  }

2.后端返回的是文件流

1)设置请求头

// 导出用户数据查询(封装的接口)
export function ExpUserList(StartDate, EndDate, DistrictCode, IsNormal, Age) {
	return request({
		url: 'admin/Export/ExpUserList.ashx' + '?token=' + getToken() + '&StartDate=' + StartDate +
			'&EndDate=' + EndDate + '&DistrictCode=' + DistrictCode + '&IsNormal=' + IsNormal + '&Age=' + Age,
		method: 'Get',
		responseType: 'blob' //指明返回格式( 需要在此处设置请求头,设置请求的类型为blob文件流的形式)
	})
}

2)设置返回结果,处理返回的文件流

// 页面代码
<el-button
    type="primary"
    size="mini"
    class="filter-item"
    icon="el-icon-download"
    @click="exportFun">
       导出
 </el-button>
 
//调用导出接口
exportFun() {
	ExpUserList(this.listQuery.StartDate, this.listQuery.EndDate, this.listQuery.DistrictCode, this.listQuery
			.IsNormal, this.listQuery.Age).then(res => {
				console.log(res)
				this.exportName = `用户数据`   //导出的文件名称
				let href = window.URL.createObjectURL(new Blob([res])); //将文件流转化为blob地址
				let link = document.createElement('a'); //创建a标签
				link.style.display = 'none';
				
				// 设置连接
				link.href = href;
				link.setAttribute('download', this.exportName + '.xlsx');
				document.body.appendChild(link);
				
				//设置点击事件
				link.click();
				
				document.body.removeChild(link); // 下载完成移除元素
				window.URL.revokeObjectURL(href); // 释放掉blob对象
			})
			.catch(err => {
				console.log(err)
			})
},

3)小提示:
有的时候做到上述几步还是不能导出,debugger 之后,发现接口调用的时候直接走的.catch,没走.then,
所以需要我们在全局响应拦截做一些判断。


//一般在utils下面的requext.js文件里面
export function validResponse(res, errorMessage) {
    if (res instanceof Blob) {  //如果返回的是文件流的形式,直接return res
        return res
    } else if (res.code !== 200 && res.code !== 201 && res.code !== 204) {
        return Promise.reject(new Error(res.message || '发生错误!'))
    } else {
        return res
    }
}

八、el-radio (单选框) 绑定 —字符串\数字\布尔类型

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/333124.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

化繁为简|中信建投基于StarRocks构建统一查询服务平台

近年来&#xff0c;在证券服务逐渐互联网化&#xff0c;以及券商牌照红利逐渐消退的行业背景下&#xff0c;中信建投不断加大对数字化的投入&#xff0c;尤其重视数据基础设施的建设&#xff0c;期望在客户服务、经营管理等多方面由经验依赖向数据驱动转变&#xff0c;从而提高…

面试阿里测开岗,面试官说我不配24K,当场拍桌子翻脸....

好家伙&#xff0c;这奇葩事可真是多&#xff0c;前两天和粉丝聊天&#xff0c;他说前段时间面试阿里的测开岗&#xff0c;最后和面试官干起来了。 我问他为什么&#xff0c;他说没啥&#xff0c;就觉得面试官太装了&#xff0c;我说要24K&#xff0c;他说太高了&#xff0c;说…

中国区注册OpenAI账号试用ChatGPT指南

OpenAI最近推出ChatGPT&#xff0c;但国内&#xff08;包括香港&#xff09;并不支持OpenAI账号注册&#xff0c;多数会提示&#xff1a; OpenAI’s services are not available in your country. 前期准备 科学上网&#xff0c;最好是美国IP&#xff08;可以购买v屁n&#xf…

章鱼哥听歌

uboot环境变量 以下所有的命令&#xff0c;都在串口工具进行执行 ubifsmount- mount UBIFS volume ubifsumount- unmount UBIFS volume ums - Use the UMS [USB Mass Storage] usb - USB sub-system usbboot - boot from USB device version - print monit…

EasyX精准帧率控制打气球小游戏

&#x1f386;音乐分享 New Boy —— 房东的猫 之前都用Sleep&#xff08;&#xff09;来控制画面帧率&#xff0c;忽略了绘制画面的时间 如果绘制画面需要很长的时间&#xff0c;那么就不能忽略了。 并且Sleep&#xff08;&#xff09;函数也不是特别准确&#xff0c;那么就…

day3——有关java运算符的笔记

今天主要学习的内容有java的运算符 赋值运算符算数运算符关系运算符逻辑运算符位运算符&#xff08;专门写一篇笔记&#xff09;条件运算符运算符的优先级流程控制 赋值运算符 赋值运算符&#xff08;&#xff09;主要用于给变量赋值&#xff0c;可以跟算数运算符相结合&…

【✨十五天搞定电工基础】基本放大电路

本章要求1. 理解放大电路的放大作用和共发射极放大电路的性能特点&#xff1b; 2. 掌握静态工作点的估算方法和放大电路的微变等效电路分析法&#xff1b; 3. 了解放大电路输入、输出电阻和电压放大倍数的计算方法&#xff0c;了解放大电路的频率特性、 互补功率放大…

八、STM32串口通信

目录 一、串口通信 1.1串口通信物理层 1.2USB转串口模块 1.3串口通信的其他应用 1.4串口数据包的基本组成 二、串口的结构体与函数讲解 2.1串口讲解 2.2结构体讲解 2.3串口初始化函数讲解 三、串口发送字符 3.1如何配置串口的发送 3.2项目实战 四、串口的中断接收 …

一文搞懂 什么是CPU上下文?为什么要切换?如何减少切换?

最近经常有小伙伴问到的一些问题&#xff0c;比较集中的是关于CPU切换. 实际用C/C&#xff0c;go开发&#xff0c;你会特别注意内存和CPU的使用情况&#xff0c;那些对于CPU使用情况特别关注&#xff0c;或者性能特别关注的朋友可以看看这篇文章&#xff0c;相信看完结尾的示例…

二、Linux文件 - Open函数讲解实战

目录 1.Open函数讲解 2.open函数实战 2.1 man 1 ls 查询Shell命令 2.2 man 2 open 查看系统调用函数 2.3项目实战 2.3.1O_RDWR和O_CREAT 2.3.2O_APPEND的用法 1.Open函数讲解 高频使用的Linux系统调用&#xff1a;open write read close Linux自带的工具&#xf…

C语言实现五子棋(n子棋)

五子棋的历史背景&#xff1a; 五子棋起源于中国&#xff0c;是全国智力运动会竞技项目之一&#xff0c;是一种两人对弈的纯策略型棋类游戏。双方分别使用黑白两色的棋子&#xff0c;下在棋盘直线与横线的交叉点上&#xff0c;先形成五子连珠者获胜。五子棋容易上手&#xff0c…

c/c++开发,无可避免的文件访问开发案例

一、缓存文件系统 ANSI C标准中的C语言库提供了fopen, fclose, fread, fwrite, fgetc, fgets, fputc, fputs, freopen, fseek, ftell, rewind等标准函数&#xff0c;这些函数在不同的操作系统中应该调用不同的内核API&#xff0c;从而支持开发者跨平台实现对文件的访问。 在Lin…

【九宫格坐标排列 Objective-C语言】

一、这个案例做好之后的效果如图: 1.这个下载是可以点击的,当你点击之后,弹出一个框,过一会儿,框框自动消失,这里变成“已安装” 2.那么,我现在先问大家一句话:大家认为在这一个应用里面,它包含几个控件, 3个,哪3个:一个是图片框,一个是Label,一个是按钮, 这…

python学习笔记-查看数据结构、均值、中位数、分位数、众数、离中趋势(标准差、方差、求和、偏态系数、风险系数)正态分布pdf、cdf、ppf

①引入pandas包&#xff0c;命名为pd。 import pandas as pd ②读入HR.csv数据 dfpd.read_csv(“./data/HR.csv”) ③查看是什么结构 type(df) ④查看单个类别satisfaction_level的数据结构 type(df[“satisfaction_level”]) ⑤查看均值的数据结构 type(df.mean()) …

运行Whisper笔记(1)

最近chatGPT很火&#xff0c;就去逛了一下openai的github项目。发现了这个项目。 这个项目可以识别视频中的音频&#xff0c;转换出字幕。 带着一颗好奇的心就尝试自己去部署玩一玩 跟着这篇文章一步步来进行安装&#xff0c;并且跟着这篇文章解决途中遇到的问题。 途中还会遇…

男,26岁,做了一年多的自动化测试,最近在纠结要不要转行,求指点。?

最近一个粉丝在后台问我&#xff0c;啊大佬我现在26了&#xff0c;做了做了一年多的自动化测试&#xff0c;最近在纠结要不要转行&#xff0c;求指点。首选做IT这条路&#xff0c;就是很普通的技术蓝领。对于大部分来说干一辈子问题不大&#xff0c;但是发不了什么财。如果你在…

第015天:将APP发布到应用商店(完结)

应用已经开发出来了&#xff0c;下一步我们需要思考推广方面的工作。那么如何才能让更多的用户知 道并使用我们的应用程序呢&#xff1f;在手机领域&#xff0c;最常见的做法就是将程序发布到某个应用商店中&#xff0c;这 样用户就可以通过商店找到我们的应用程序&#xff0c;…

前端修行 - 与后端配合的那些事情

最近总结一下个人作为前端&#xff0c;与后端、测试、以及产品经理、UI设计之间配合的那些事情&#xff0c;想到哪里说到哪里 1 关于正确认识项目研发一号位都是后端的这个事情 项目研发一号位&#xff0c;在有的公司可能会叫做SDM&#xff08;software development manger&am…

springboot 接入websocket实现定时推送消息到客户端

目录说明代码实现说明 如标题&#xff0c;举例需求场景&#xff1a; 前端与后端websocket连接上后&#xff0c;多用户登录&#xff0c;后端根据不同用户定时发消息给前端用于展示 代码实现 1、 <dependency><groupId>org.springframework.boot</groupId>…

vit-pytorch实现 MobileViT注意力可视化

项目链接 https://github.com/lucidrains/vit-pytorch 注意一下参数设置&#xff1a; Parameters image_size: int. Image size. If you have rectangular images, make sure your image size is the maximum of the width and heightpatch_size: int. Number of patches. im…