翻页组件page-flip调用问题
翻页组件重新调用解决方案
翻页组件:page-flip
import { PageFlip } from 'page-flip'
pagefile() {
//绘制翻页
this.pageFlip = new PageFlip(document.getElementById('demoBookExample1'), {
width: 500, // base page width
height: 500, // base page height
size: 'stretch',
// set threshold values:
// drawShadow: false,
minWidth: 350,
maxWidth: 550,
minHeight: 420,
maxHeight: 550,
// clickEventForward:false,
disableFlipByClick: true,
maxShadowOpacity: 0.5, // Half shadow intensity
showCover: true,
mobileScrollSupport: false // disable content scrolling on mobile devices
})
this.PageShow()
}
PageShow() {//加载翻页
this.pageFlip.loadFromHTML(document.querySelectorAll('.shipfiles_page2'))
// // triggered by page turning
this.pageFlip.on('flip', e => {
e, 'fil['
})
// // triggered when the state of the book changes
this.pageFlip.on('changeState', e => {
e, 'eeeeeeeeeeeee'
if (e.data == 'flipping') {
}
})
// // triggered when page orientation changes
this.pageFlip.on('changeOrientation', e => {})
},
`跳转翻页`
this.pageFlip.flip(页码:Number)
`DOM结构查看官网`
https://nodlik.github.io/StPageFlip/
问题发现+尝试解决方案
问题发现
#翻页组件方法再次被调用时,原来的翻页组件样式还保留在页面,而且新生成的翻页组件内容直接在组件外面,没有放在里面
尝试解决方案
`(1)使用翻页组件API的destroy方法销毁,生成新的翻页组件无法获取节点`
`(2)使用翻页组件API的updateHTML方法更新节点,生成的翻页组件没有封面样式`
`(3)使用DOM节点保存数据,等翻页组件再次调用时只更新数据再销毁上个节点和数据,
重新再调用保存的DOM节点,页面样式出现空白透明翻页`
`(4)使用路由跳转刷新页面,让翻页组件只被调用一次(created时调用查到数据时调用翻页组件),
路由菜单是前端的可能可行,如果路由是后台动态生成的,这个方法只能实现刷新跳到进入的默认页面`
`(5)使用父子组件,将翻页组件当成一个子组件,父组件将数据传到子组件,出现空白透明翻页,
上一次数据未被清除,翻页组件可能无法识别动态数据`
解决方案
#此方法直接控制翻页组件的生成销毁,使翻页组件只调用了一次数据
import book from './book.vue' //存放翻页组件
`动态生成组件,控制组件生成`
<component :ImgList="ImgList" :is="componentName"></component>
`created`
results() //获取到初始数据
`methods`
change() //获取到更新数据
--->this.componentName='' //改变时清掉动态组件
--->this.results() //获取数据
results(){
ImgList //获取到数据
this.nextTick(()=>{
this.componentName = 'book' //查到数据时重新生成组件
})
}
解决主要问题的后续
#解决控制翻页组件调用后
(1)点击控制页码(页码不在翻页样式中)让翻页组件翻页---this.pageFlip.flip(页码) 页码:page
`问题出现`:父组件的方法不能控制子组件的翻页,翻页组件的内容都在子组件
`问题解决`:将页码通过prop传到子组件,子组件再watch监听页码的变化翻页
watch:{
page(newVal){
this.pageFlip.flip(newVal)
}
}
(2)子组件的方法在父组件上实现(PreviewImg)
`问题出现`:点击翻页组件的图片让它放大,方法在子组件上,放大的内容在父组件上
`问题解决`:通过emit将子组件的数据传到父组件,父组件拿到数据后控制图片的放大
<component :ImgList="ImgList" :is="componentName" :page="page" @PreviewImg="PreviewImg"></component>
翻页组件page-flip调用问题的更多相关文章
- 一款易用、高可定制的vue翻页组件
一款易用.高可定制的vue翻页组件 在线体验:pages.cixi518.com 使用 npm i vo-pages --save vo-pages组件父元素必须设置固定高度并填写属性overflow ...
- Atitit easyui翻页组件与vue的集成解决方案attilax总结
Atitit easyui翻页组件与vue的集成解决方案attilax总结 ===============使用1 ===========\paggingUtil_easyui_vue.js2 C:\U ...
- Atitit 翻页功能的解决方案与版本历史 v4 r49
Atitit 翻页功能的解决方案与版本历史 v4 r49 1. 版本历史与分支版本,项目版本记录1 1.1. 主干版本历史1 1.2. 分支版本 项目版本记录.1 2. Easyui 的翻页组件2 ...
- webapp应用--模拟电子书翻页效果
前言: 现在移动互联网发展火热,手机上网的用户越来越多,甚至大有超过pc访问的趋势.所以,用web程序做出仿原生效果的移动应用,也变得越来越流行了.这种程序也就是我们常说的单页应用程序,它也有一个英文 ...
- vue翻页器,包括上一页,下一页,跳转
翻页组件 -- 子组件<template> <div class="pager-wrapper" ref="pager"> <di ...
- element-ui table 的翻页记忆选中
公司中台项目刚开始开发,用了vue+element,需要许多前置调研,table的翻译记忆选中就是其中之一. template: <el-table :ref="tableRef&qu ...
- 解决Hexo博客模板hexo-theme-next的翻页按钮不正常显示问题
用Hexo搭了个Gitpage的博客,兴冲冲的发了11篇博文后发现翻页按钮不正常显示,显示为<i class="fa fa-angle-right"></i> ...
- Atitit.pagging 翻页功能解决方案专题 与 目录大纲 v3 r44.docx
Atitit.pagging 翻页功能解决方案专题 与 目录大纲 v3 r44.docx 1.1. 翻页的重要意义1 1.2. Dep废弃文档 paip.js翻页分页pageing组件.txt1 ...
- Web jquery表格组件 JQGrid 的使用 - 5.Pager翻页、搜索、格式化、自定义按钮
系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...
随机推荐
- Top 15 - Material Design框架和类库(译)
_Material design_是Google开发的,目的是为了统一公司的web端和手机端的产品风格.它是基于很多的原则,比如像合适的动画,响应式,以及颜色和阴影的使用.完整的指南详情请看这里(ht ...
- 耗时一个月上架了一款微信小程序,赚了2022年的第一笔副收入
今天不谈技术,只谈经历. 前戏 相信有很多的程序员都有一个产品梦,希望有一款属于自己产品.毕竟工作中遇到的有些"脑残"的产品经理不是一个两个,最后不得不因为"技术服务于业 ...
- Python入门-第一行代码到多行代码
不管学啥语言,开始的第一行代码都是: print("hello word") 回车之后,就代表你正式进入代码的世界! 如果报错,恭喜你获得第一个书写bug,请检查单词拼写,双引号, ...
- CVE 公开披露的网络安全漏洞列表
CVE®是一份公开披露的网络安全漏洞列表, 官方地址为 : https://cve.mitre.org/cve/ 比如 mavenrepository 上阿里的Druid修复的漏洞的列表如下:
- 自己写的一个Hash文件校验软件
原因 学校网络安全课讲到了Hash函数,老师提了一句上机操作的时候可以用自己的写的文件校验软件,所以我干脆就自己写一个. 说明 支持算法 MD5 SHA1 SHA256 SHA512 SHA384 为 ...
- 基于HiKariCP组件,分析连接池原理
HiKariCP作为SpringBoot2框架的默认连接池,号称是跑的最快的连接池,数据库连接池与之前两篇提到的线程池和对象池,从设计的原理上都是基于池化思想,只是在实现方式上有各自的特点:
- 解决zabbix5字体中文口口乱码
环境信息 系统:Ubuntu20.04 zabbix版本:5.4 解决方法一 此方法比较偷懒,就是不改变zabbix相关配置,直接用原名替换字体文件. 原字体字体名称为DejaVuSans.将方法二的 ...
- 认识python-个人笔记篇
认识python 1 .python 的发展历史 一种广泛使用的解释型.高级编程.通用型编程语言,由"龟叔"吉多·范罗苏姆创造,第一版发布于1991年. Python的设计哲学强调 ...
- iOS全埋点解决方案-手势采集
前言 随着科技以及业务的发展,手势的应用也越来越普及,因此对于数据采集,我们要考虑如果通过全埋点来实现手势的采集. 一.手势识别器 苹果为了降低开发者在手势事件处理方面的开发难度,定义了一个抽 ...
- PicLite 开发日志 v0.0.2
PicLite 开发日志 (v0.0.2) 感谢您阅读本片文章! Gitee 地址:https://gitee.com/XiaoQuQuSD/pic-lite. 新增功能 添加复制 url 的格式选项 ...