Search code examples
javascriptiphonefocusmootoolscordova

How can I focus on an input field when a phonegap page loads?


I would like to focus on a text input in a PhoneGap application when the page loads. I have tried the MooTools version $('entry').focus(); and document.getElementById('entry').focus() when the DOM is ready.

This works fine when the HTML page is viewed in a normal web browser, but in the iPhone simulator running PhoneGap, it doesn't work.

Is there a way to focus on a form field for iPhones that forces the virtual keyboard to appear?


Solution

  • As of iOS 6, the UIWebView class has a property called "keyboardDisplayRequiresUserAction". If you want to programmatically focus text form elements, set this to false via your phonegap config.xml:

    <preference name="KeyboardDisplayRequiresUserAction" value="false" />
    

    The default value is true.

    More here: http://community.phonegap.com/nitobi/topics/calling_focus