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知识库 -> 小程序——uniapp实现二维码图片弹窗、保存图片功能 -> 正文阅读

[JavaScript知识库]小程序——uniapp实现二维码图片弹窗、保存图片功能

小程序uniapp需要实现一个点击某个按钮后,弹出二维码图片,并且有保存图片的功能。

在这里插入图片描述

代码实现:
html部分:
使用uniapp中的unipopup组件进行弹窗

<uni-popup ref="kefu" type="center" :mask-click="false" class="kefu">
	<view class="popup">
		<view class="icon-close">
			<uni-icons type="close" size="30" @click="close" color="#fff">
			</uni-icons>
		</view>
		<image src="../../static/images/showModal/qrcode.png" mode="widthFix" 
		class="QRcode"></image>
		<button type="warn" size="default" class="btn-savecode" 
		@click="saveQRcode">保存图片</button>
	</view>
</uni-popup>

css部分:

注意事项:
由于uniapp的unipoup组件有隐藏的白色背景,以及当字体图标需要出现在图片右上角时,所以需要修改组件类css中的background-color为透明,overfloew-y防止图标远离图片后会被隐藏

/deep/.uni-popup__wrapper.uni-custom.center  .uni-popup__wrapper-box{
	background-color: transparent;
	position: relative;
	max-width: 80%;
	max-height: 80%;
	overflow-y: visible;
	.popup{
		width: 100%;
		.icon-close{
			display: block;
			text-align: right;
			margin-right: -60rpx;
		}
		.QRcode{
			width: 450rpx;
			display: block;
		}
		.btn-savecode{
			margin: 20rpx 100rpx;
			border-radius: 50rpx;
			font-size: 30rpx;
		}
	}
}

JS部分:
Uniapp在使用uni.authorize进行授权时,如果用户第一次点击拒绝,再次想进行授权时,发现授权页面无法弹出,而会直接授权失败,非常影响用户体验。这时需要弹出提醒,让用户手动设置授权。

saveQRcode(){
	uni.getSetting({
		success:(res)=>{
			if(res.authSetting['scope.writePhotosAlbum']){ //验证用户是否授权可以访问相册
				this.saveQRcodeToPhotosAlbum();
			}else{
				uni.authorize({
					scope:'scope.writePhotosAlbum',
					success:(res)=>{
						console.log('有授权的信息:',res);
						this.saveQRcodeToPhotosAlbum();
					},
					fail:(err)=>{ //取消授权后再获取授权,需手动设置
						uni.showModal({
							content:'检测到你没打开保存相册权限,是否去设置打开',
							confirmText:'确认',
							cancelText:'取消',
							success(res){
								if(res.confirm){
									uni.openSetting({
										success(res) {
											console.log('授权成功');
										}
									})
								}else{
									console.log('取消授权');
								}
							}
						})
					}
				})
			}
		}
	})
},
saveQRcodeToPhotosAlbum(){
	let that = this
			uni.saveImageToPhotosAlbum({
				filePath:'static/images/showModal/qrcode.png',
				success(res) {
					uni.showToast({
						title:'保存成功',
						icon:'success'
					})
					that.close()
				},
				fail(err){
					console.log(err);
				}
			})
		}
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-02-28 15:20:07  更:2022-02-28 15:21:48 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 10:00:22-

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