在移动端开发中提交表单,苹果端显示正常,但是在安卓上显示异常,顶起键盘会让输入框顶到莫名其妙的位置。本文旨在解决这种怪异的样式问题。
 
定义初始高度
| 12
 3
 4
 5
 6
 7
 
 | data(){return {
 screenHeight: document.body.clientHeight,
 originHeight: document.body.clientHeight,
 isOriginHei: true
 }
 }
 
 | 
created里面判断类型
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 
 | const ua = navigator.userAgent;const self = this;
 if (ua.indexOf("Android") > -1 || ua.indexOf("Adr") > -1) 	{
 this.platform = "android";
 window.onresize = () => {
 return (() => {
 
 self.screenHeight = document.body.clientHeight;
 })();
 };
 }
 
 | 
watch监听视图变化
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 
 | watch: {
 screenHeight(val) {
 
 const that = this;
 if (this.originHeight - val > 50) {
 
 that.$nextTick(() => {
 const y = that.$refs[that.dom].offsetTop - 80;
 document.body.scrollTop = y;
 document.documentElement.scrollTop = y;
 window.scrollTo(0, y);
 });
 } else {
 
 document.body.scrollTop = 0;
 document.documentElement.scrollTop = 0;
 window.scrollTo(0, 0);
 }
 }
 }
 
 |