javascript - why iOS mobile cannot use focus() - Stack Overflow

I'm trying to use the javascript function focus(), but it does not work on safari mobile. How do I

I'm trying to use the javascript function focus(), but it does not work on safari mobile. How do I fix this problem?

<html lang="en">
   <head>
      <meta charset="UTF-8">
      <title>demo</title>
      <script type="text/javascript">
         window.onload=function() {
           document.getElementById('username').focus();
         }
      </script>
   </head>
   <body>
     <input type="text" id="username" >
     <input type="text" >
   </body>
</html>

I'm trying to use the javascript function focus(), but it does not work on safari mobile. How do I fix this problem?

<html lang="en">
   <head>
      <meta charset="UTF-8">
      <title>demo</title>
      <script type="text/javascript">
         window.onload=function() {
           document.getElementById('username').focus();
         }
      </script>
   </head>
   <body>
     <input type="text" id="username" >
     <input type="text" >
   </body>
</html>
Share Improve this question edited Jan 14, 2016 at 8:59 Dmitriy 5,56512 gold badges27 silver badges39 bronze badges asked Jan 14, 2016 at 8:11 VagorVagor 211 silver badge2 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 4

iOS does not allow .focus() to be fired automatically for security reason.

I was having the same problem with an Angular app, and I solved it with a very simple hack.

For starters, you might want to use jQuery; it makes a lot of things clear-cut for you and is more-or-less fully supported. Then, try doing this:

$( document ).ready( function() {

    setTimeout( $( '#username' ).focus(), 0 );

});

Now, I don't exactly know how it works; maybe some rendering issue. But it works for sure.

If you want VanillaJS:

window.onload = function() {

    setTimeout( document
                  .getElementById( 'username' ).focus(), 0 );

}

I don't know if the VanillaJS version will work.

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1745558876a4632985.html

相关推荐

  • javascript - why iOS mobile cannot use focus() - Stack Overflow

    I'm trying to use the javascript function focus(), but it does not work on safari mobile. How do I

    17小时前
    20

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信