xl_echo编辑整理,欢迎转载,转载请声明文章来源。欢迎添加echo微信(微信号:t2421499075)交流学习。 百战不败,依不自称常胜,百败不颓,依能奋力前行。——这才是真正的堪称强大!!html
在使用iview的时候,对于界面效果确实是比较满意,提供的组件也不少的很全,和element相比,iview更注重视觉和渲染。可是也有一些缺点,好比组件的bug,生态圈的收费问题。这里只讲解page的跳转bugchrome
能够看到并无跳转的按钮,若是要跳转的话,必须输入页数以后按'enter'键,若是不按无法跳转。对于用户来讲,电脑的操做水平不一,不少人可能没有enter的意识,这样就形成了这个功能的鸡肋,因此须要修复浏览器
<Page :id="pageId" :total="total" :current="page" @on-change="changePage" @on-page-size-change="changesPages" show-sizer show-elevator >
</Page>
<div style="float: left;margin-right: 10px;margin-top: 12px">
<Button type="primary" size="small" @click="goElevatorPage(pageId)">跳转</Button>
</div>
复制代码
加上按钮以后咱们并无实现功能,只是看起来比较像而已。bash
编写点击跳转方法以前要如今page组件中添加:id="pageId"
,并在return当中定义对应pageId的值。我这里定义以下:微信
return {
pageId: "targetpage",
}
复制代码
完成以后,编写跳转方法,以下:iview
goElevatorPage:function(pageId){
var evtObj;
var thisPage=document.getElementById(pageId);
var elevatorDiv=thisPage.getElementsByClassName("ivu-page-options-elevator");
if(elevatorDiv && elevatorDiv.length>0){
var pageInput = elevatorDiv[0].getElementsByTagName("input")[0];
if (window.KeyEvent) {//firefox 浏览器下模拟事件
evtObj = document.createEvent('KeyEvents');
evtObj.initKeyEvent("keyup", true, true, window, true, false, false, false, 13, 0);
} else {//chrome 浏览器下模拟事件
evtObj = document.createEvent('UIEvents');
evtObj.initUIEvent("keyup", true, true, window, 1);
delete evtObj.keyCode;
if (typeof evtObj.keyCode === "undefined") {//为了模拟keycode
Object.defineProperty(evtObj, "keyCode", { value: 13 });
} else {
evtObj.key = String.fromCharCode(13);
}
}
pageInput.dispatchEvent(evtObj);
}
}
复制代码
若是在这个页面中间有不少个page组件,那么这里只能实现一个page组件的跳转,若是须要多个page组件都有这个功能,模拟跳转方法,只须要一个便可,关键是要在page组件中添加:id="pageId"
一个page对应一个不一样的id值,在对应调用方法的地方传入对应id值接口。学习
好比我点击跳转按钮以后,跳转到了响应页面。到了相应页面以后,不改变当前须要跳转的页面值的时候,再次点击跳转按钮,是没有反应的。ui