当我将焦点放在iScroll视图底部的表单字段时,它不会向上滚动/将焦点字段带到softkeyboad上方。任何的想法?谢谢!
这是Android项目。 https://dl.dropboxusercontent.com/u/75818136/webkitdemo.zip
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=0, minimum-scale=1.0, maximum-scale=1.0">
<title>iScroll demo: simple</title>
<style type="text/css" media="all">
body,ul,li {
padding:0;
margin:0;
border:0;
}
body {
font-size:12px;
-webkit-user-select:none;
-webkit-text-size-adjust:none;
font-family:helvetica;
}
#header {
position:absolute; z-index:2;
top:0; left:0;
width:100%;
height:45px;
line-height:45px;
background-color:#d51875;
background-image:-webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #fe96c9), color-stop(0.05, #d51875), color-stop(1, #7b0a2e));
background-image:-moz-linear-gradient(top, #fe96c9, #d51875 5%, #7b0a2e);
background-image:-o-linear-gradient(top, #fe96c9, #d51875 5%, #7b0a2e);
padding:0;
color:#eee;
font-size:20px;
text-align:center;
}
#header a {
color:#f3f3f3;
text-decoration:none;
font-weight:bold;
text-shadow:0 -1px 0 rgba(0,0,0,0.5);
}
#footer {
position:absolute; z-index:2;
bottom:0; left:0;
width:100%;
height:48px;
background-color:#222;
background-image:-webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #999), color-stop(0.02, #666), color-stop(1, #222));
background-image:-moz-linear-gradient(top, #999, #666 2%, #222);
background-image:-o-linear-gradient(top, #999, #666 2%, #222);
padding:0;
border-top:1px solid #444;
}
#wrapper {
position:absolute; z-index:1;
top:45px; bottom:48px; left:0;
width:100%;
background:#aaa;
overflow:auto;
}
#scroller {
position:absolute; z-index:1;
/* -webkit-touch-callout:none;*/
-webkit-tap-highlight-color:rgba(0,0,0,0);
width:100%;
padding:0;
}
#scroller ul {
list-style:none;
padding:0;
margin:0;
width:100%;
text-align:left;
}
#scroller li {
padding:0 10px;
height:40px;
line-height:40px;
border-bottom:1px solid #ccc;
border-top:1px solid #fff;
background-color:#fafafa;
font-size:14px;
}
</style>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="iscroll.js"></script>
</head>
<body>
<div id="header"><a href="http://cubiq.org/iscroll">iScroll</a></div>
<div id="wrapper">
<div id="scroller">
<ul id="thelist">
<li>Pretty row 1</li>
<li>Pretty row 2</li>
<li>Pretty row 3</li>
<li>Pretty row 4</li>
<li>Pretty row 5</li>
<li>Pretty row 6</li>
<li>Pretty row 7</li>
<li>Pretty row 8</li>
<li>Pretty row 9</li>
<li>Pretty row 10</li>
<li>Pretty row 11</li>
<li>Pretty row 12</li>
<li>Pretty row 13</li>
<li>Pretty row 14</li>
<li>Pretty row 15</li>
<li>Pretty row 16</li>
<li>Pretty row 17</li>
<li>Pretty row 18</li>
<li>Pretty row 19</li>
<li>Pretty row 20</li>
<li>Pretty row 21</li>
<li>Pretty row 22</li>
<li>Pretty row 23</li>
<li>Pretty row 24</li>
<li>Pretty row 25</li>
<li>Pretty row 26</li>
<li>Pretty row 27</li>
<li>Pretty row 28</li>
<li>Pretty row 29</li>
<li>Pretty row 30</li>
<li>Pretty row 31</li>
<li>Pretty row 32</li>
<li>Pretty row 33</li>
<li>Pretty row 34</li>
<li>Pretty row 35</li>
<li>Pretty row 36</li>
<li>Pretty row 37</li>
<li>Pretty row 38</li>
<li>Pretty row 39</li>
<li><form><input type="text" value="hey" spellcheck="false"></form></li>
</ul>
</div>
</div>
<div id="footer"></div>
<script>
var myScroll;
function loaded() {
myScroll = new iScroll('wrapper');
}
document.addEventListener('touchmove', function (e) { e.preventDefault(); }, false);
document.addEventListener('DOMContentLoaded', function () { setTimeout(loaded, 200); }, false);
window.addEventListener("resize", function() {
console.error("=------======-=-=-==");
}, false);
</script>
</body>
</html>
答案 0 :(得分:7)
我终于找到了我的问题的解决方案。顺便说一句,这个解决方案将出现在我的书中,该书将很快出版。我只是想与开发者社区分享这个。
首先,iscroll应该为我们处理这件事,但不知道它不会。
另外,我认为Android API存在一个错误。当我使用全屏模式(在清单或编程中)时,“调整大小”事件不会在WebView中被触发。不知道为什么。我已经向Android团队报告了这个错误。如果你知道为什么会这样,请在这里告诉我们。感谢。
android:theme="@android:style/Theme.NoTitleBar.Fullscreen"
// or
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);
以下是解决方案:
我删除了全屏模式。相反,我在应用程序中使用res/values/style.xml
,requestWindowFeature(android.view.Window.FEATURE_NO_TITLE);
和android:theme="@style/Theme"
来删除应用程序本机标题。当方向发生时,此解决方案也有效。
然后,使用“焦点”事件,我捕获了哪个元素具有焦点。
var $elm;
$('input, textarea').bind('focus', function(e) {
console.error("onFocus");
$elm = $(this);
});
然后,使用“resize”事件,我刷新了iscroll对象,然后滚动到$ elm。
$(window).bind('resize', function() {
console.error("onResize");
if (myScroll !== undefined) {
setTimeout(function() {
myScroll.refresh();
myScroll.scrollToElement($elm[0], 200);
}, 100);
}
});
答案 1 :(得分:2)
我不确定这是否适合您的问题。我已经遇到过soft keyboard
&amp; POS设备中的iscroll
。为了解决这个问题,我做了 STUPID 工作。
我已经完成的步骤。
假设你像这样附上了iScroll
iScrollObj =新的iScroll('ID');
pi
)和输入的高度(hi
)hs
),键盘的高度(hk
)hs
,hk
,hi
和pi
我计算了一个空白div包装器并分配给它的高度。iScrollObj.refresh()
回调函数。(因为我已经动态地为div包装器分配了高度,iScroll有时会对动态调整进行正确响应,但有时会失败)iScrollObj.scrollTo(x, y, time)
iScroll回调函数向上移动输入iScrollObj.refresh()
和iScrollObj.scrollTo(x, y, time)
仍然可以使用iScrollObj.scrollToElement(element, time)
,但我认为这是更多的工作。因为element
应该是元素的CSS selector
,其中iScroll会自动滚动到该元素,在该元素中,该元素在视图的顶部位置显示该元素。这意味着您附加的屏幕会显示如果您使用CSS selector
的{{1}},那么它会从Pretty row 34
显示为向下。
请注意
我使用的 Pretty row 34
是由我开发的(它是一个jQuery插件),因此我能够实现所有必需的回调函数。 Soft keyboard
已经提供了很多回调函数。
因此我能够完成我的任务并且它正常工作 没有任何问题,我们期待。
我不知道你有什么约束。刚刚分享了我所做的STUPID工作。
请原谅我,如果这不适合你。
感谢。