zoukankan      html  css  js  c++  java
  • MUI 页面加载完成后,自动聚焦指定input元素问题解决

    背景:MUI+VUE开发app;
    实现功能:页面初始化后input自动聚焦;
    聚焦方法:mui('.XXX')[0].focus();
    问题:大部分页面自动聚焦成功,小部分页面自动聚焦偶尔成功;
    猜测一 > 页面未加载完成时执行聚焦方法?
     处理方式1:将聚焦方法放在“mui.plusReady”最后面;
     处理方式2:添加延时setTimeout(function(){},2000);
     处理方式3:使用Vue的自定义指令,在input添加v-focus;

    directives:{
    	focus:function(el){
    		el.focus();
    	}
    }
    

    以上方式均不起效果,还是偶尔成功。
    猜测二 > mui.openWindow()打开页面过多,mui('.XXX')[0]找不到dom元素
     处理方式4:使用document.getElementById('XXX').focus();
     处理方式5:关闭其他页面

    var otherPage= plus.webview.getWebviewById('otherPage.html');
    plus.webview.close(otherPage);
    

    成功了!!
    关闭其他已打开页面,页面回退就有问题,所以不能这样修改。
    计划获取通过plus.webview.currentWebview()获取页面中的‘XXX’对象进行处理,但是plus.webview.WebviewObject对象中没有。

    -------------------------------------------分割线---------------------------------------------------
    最终解决方式:修改上级页面js部分的跳转按钮事件绑定代码
    修改前:mui('.js-confirm')[0].addEventListener('tap', function() {});
    修改后:mui('body').on('tap','.js-confirm',function(){}),如下图:

    总结:很难想到聚焦失败的原因,不是当前页面的js影响,而且受到上级页面的js跳转按钮事件绑定方式影响,
    不知道算不算是mui的bug。

    待聚焦页面js部分代码:

  • 相关阅读:
    知识管理(knowledge Management)2
    Maven手动添加依赖的jar文件到本地Maven仓库
    Maven手动添加依赖的jar文件到本地Maven仓库
    Jquery 操作 Select 详解
    Jquery 操作 Select 详解
    JSTL获取当日时间与数据时间比较
    JSTL获取当日时间与数据时间比较
    MySQL免安装版配置部署
    MySQL免安装版配置部署
    JS比较两个日期大小
  • 原文地址:https://www.cnblogs.com/chonghaojie/p/11321648.html
Copyright © 2011-2022 走看看