【webView中打开pdf文件,再点击设置切换页面后,再点击返回,则pdf无法正常显示,显示空白?】

https://developers.weixin.qq.com/community/develop/doc/000ea83ba5cb58a586feb827c59c00跟这个问题一样
解决办法就是在onshow中奖地址清了重新赋值,就是缓存的问题

<div>
		<web-view :src="pdfurl" :webview-styles="webviewStyles" >
			<cover-view class="share-button">
				<cover-view class="share-txt" >
					<cover-image @click="goPages(`/subPages/Industry/report/download?src=${pdfurl}&title=${title}`)" class="share-img" src="https://static.solarbe.com/zhangshang/xiazai.png"></cover-image>
				</cover-view>
			</cover-view>
		</web-view>
		(生成分享图片)
		<canvas class="canvas" canvas-id="imgCanvas" style="width: 100%;height: 100%;position: absolute; top: -1000px; left: -1000px;"></canvas>
	</div>
<script>
	import {reportLog} from '@/api/report/index.js'
	import util from '@/common/js/util.js';
	import {reportLists} from '@/api/report/index.js'
	export default{
		data(){
			return{
				title:'',
				desc:'',
				reportId:0,
				pdfurl:'',
				powerw: 0,
				shareUrl:'',
				webviewStyles: {
					progress: {
						color: '#FF3333'
					}
				}
			}
		},
		//分享到聊天
		onShareAppMessage() {
			console.log(this.shareUrl,'this.shareUrl')
			return {
				title: this.title,
				path: '/subPages/Industry/webView?title='+this.title+'&desc='+this.desc,
				imageUrl: this.shareUrl
			};
		},
		onShow() {
			 let params = {
			 	page:uni.getStorageSync('productObj').page
			 }
			 //这里一定要清除一下,不然浏览器会觉得地址一样,不做任何操作
			 this.pdfurl='';
			 //这里要重新赋值,因为他在onshow的时候没有拿到
			 reportLists(params).then((res)=>{
				 res.data.forEach((item)=>{
					 if(item.id==this.reportId||uni.getStorageSync('productObj').id){
						 this.pdfurl = item.url;
					 }
				 })
			 })
		},
		onLoad(options) {
			let {title,desc,id,url} = options
			this.title = title
			this.desc = desc
			this.reportId = id
			// this.pdfurl = decodeURIComponent(url)
			// 设置title
			uni.setNavigationBarTitle({
			  title
			})
			// 设置分享
			wx.showShareMenu({
				withShareTicket: true,
				menus: ['shareAppMessage']
			});
			// 浏览量
			this.reportLog()
			let message = uni.getSystemInfoSync(); //获取手机信息
			this.powerw = message.windowWidth / 375;
			const ctx = uni.createCanvasContext('imgCanvas');
			ctx.font = 'bold 15rpx serif'
			ctx.setTextAlign('left')
			ctx.setFillStyle("#000000")
			/**
			ctx: 画布的上下文环境
			content: 需要绘制的文本内容
			drawX: 绘制文本的x坐标
			drawY: 绘制文本的y坐标
			lineHeight:文本之间的行高
			lineMaxWidth:每行文本的最大宽度
			lineNum:最多绘制的行数
			*/
			this.textPrewrap(ctx, this.desc, 15 * this.powerw, 30 * this.powerw, 20 * this.powerw, 350, 8);
			var that = this
			ctx.draw(true, () => {
				setTimeout(function() {
					uni.canvasToTempFilePath({
						canvasId: 'imgCanvas',
						fileType: 'jpg',
						x: 0,
						y: 0,
						width: 500,
						height: 400,
						destWidth: 500,
						height: 400,
						success: function(res) {
							that.shareUrl = res.tempFilePath
							console.log(that.shareUrl,11111)
							// 在这里保存图片
						},
						fail: function(error) {
							console.log(error)
						},							
					})
				}, 100)
			})
		},
		methods:{
			reportLog(){
				let params = {
					'report_id':this.reportId
				}
				reportLog(params).then((res)=>{
					
				})
			},
			goPass(url){
				uni.redirectTo({
					url:url
				})
			},
			textPrewrap(ctx, content, drawX, drawY, lineHeight, lineMaxWidth, lineNum) {
				var drawTxt = ''; // 当前绘制的内容
				var drawLine = 1; // 第几行开始绘制
				var drawIndex = 0; // 当前绘制内容的索引
				content = content.replace(/\s*/g,"")
				// 判断内容是否可以一行绘制完毕
				if (ctx.measureText(content).width <= lineMaxWidth) {
					ctx.fillText(content.substring(drawIndex, i), drawX, drawY);
				} else {
					for (var i = 0; i < content.length; i++) {
						drawTxt += content[i];
						if (ctx.measureText(drawTxt).width >= lineMaxWidth) {
							if (drawLine >= lineNum) {
								ctx.fillText(content.substring(drawIndex, i) + '..', drawX, drawY);
								break;
							} else {
								ctx.fillText(content.substring(drawIndex, i + 1), drawX, drawY);
								drawIndex = i + 1;
								drawLine += 1;
								drawY += lineHeight;
								drawTxt = '';
								// if(uni.getSystemInfoSync().osName === "ios"){
									
								// }
								// console.log(drawY,'drawY',content)
							}
						} else {
							// 内容绘制完毕,但是剩下的内容宽度不到lineMaxWidth
							if (i === content.length - 1) {
								ctx.fillText(content.substring(drawIndex), drawX, drawY);
							}
						}
					}
				}
			},
		}
	}
</script>
<style scoped>
	image{
		width: 30rpx;
	}
	.dowload{
		height: 100rpx;
	}
	.share-button {
	  z-index: 999999;
	  position: fixed;
	  color: red;
	  display: flex;
	  justify-content: end;
	  align-items: center;
	  bottom:300rpx;
	  width:100%;
	  height: 100rpx;
	  right: 20rpx;
	}
</style>
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值