想做出来的效果是想手机淘宝那样,点搜索框跳到新页面,键盘自动出来。
淘宝是用原生的,我是 js。
试过用原生 js 和 jquery 添加 focus 事件,
也试过给一个按钮添加 click 事件绑定 input 的 focus 事件,通过触发 click 事件然后触发 focus ,
都没有用~
几十次中有那么一两次键盘能出来。
求大神指导。。。
有人也提了同样的问题
https://segmentfault.com/q/10...
想做出来的效果是想手机淘宝那样,点搜索框跳到新页面,键盘自动出来。
淘宝是用原生的,我是 js。
试过用原生 js 和 jquery 添加 focus 事件,
也试过给一个按钮添加 click 事件绑定 input 的 focus 事件,通过触发 click 事件然后触发 focus ,
都没有用~
几十次中有那么一两次键盘能出来。
求大神指导。。。
有人也提了同样的问题
https://segmentfault.com/q/10...
元素获得焦点时本来就会自动弹出虚拟键盘啊
手机访问这个页面:http://output.jsbin.com/huzuv...
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<title>JS Bin</title>
</head>
<body>
<input class="focus-element" type="tel">
<button class="get-focus">获得焦点并弹出虚拟键盘</button>
<script>
(function($){
$('.get-focus').addEventListener('click', function(){
$('.focus-element').focus();
});
})(document.querySelector.bind(document));
</script>
</body>
</html>
8 回答5.8k 阅读✓ 已解决
9 回答9.2k 阅读
6 回答4.7k 阅读✓ 已解决
5 回答3.5k 阅读✓ 已解决
4 回答7.9k 阅读✓ 已解决
7 回答9.8k 阅读
5 回答7.1k 阅读✓ 已解决
安卓我目前没有遇到问题。
然后直接使用input.focus()是无法在ios中调起键盘的,因为ios中input元素的focus必须由事件触发。
此外,如果模拟了触摸事件,但是在setTimeout中延迟执行,也是不行的。这部分可以参考stackoverflow上的case:Mobile Safari Autofocus text field.
来自FastClick团队的大牛指出了IOS下input的获取焦点存在这样的问题:
综上,要在ios中选中input并调起键盘,可以将focus调用包装在一个用户行为触发的事件中,如点击事件、表单onChange事件等。
解决方案
如果需要模拟触发事件,可以参考manually trigger touch event