13

当我关注 iScroll 视图底部的表单字段时,它不会向上滚动/将焦点字段带到软键盘上方。任何想法?谢谢!

场地 场地

这是安卓项目。 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>
4

2 回答 2

8

我终于找到了我的问题的解决方案。顺便说一句,这个解决方案将在我即将出版的书中。我只是想与开发者社区分享这个。

首先,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);
    }
});

这是我的问题的答案,WebKitDemo2.zip

于 2013-06-09T08:17:37.303 回答
2

我不确定这是否是您问题的好答案。我已经在 POS 设备中遇到了与soft keyboard&相同的问题。iscroll为了解决这个问题,我做了一个愚蠢的工作。

我已经完成的步骤。

假设您像这样附加 iScroll

iScrollObj = new iScroll('ID');

  1. 如果我有输入,我最后会在滚动容器内附加一个空的 div 包装器。
  2. 当输入元素获得焦点但在键盘弹出之前我计算输入字段的位置(pi)和输入的高度(hi
  3. 我得到屏幕高度(hs),键盘高度(hk
  4. 通过使用hs, hk,我计算了一个空 div 包装器的高度hipi分配给它。
  5. 为了避免失望,我使用iScrollObj.refresh()了回调函数。(因为我已经为 div 包装器动态分配高度,iScroll 有时会正确响应动态调整,但有时会失败)
  6. 然后我使用iScrollObj.scrollTo(x, y, time)iScroll 回调函数将输入向上移动
  7. 当我隐藏键盘时,我将空 div 包装器高度设置为 0
  8. 现在你必须重置。iScrollObj.refresh()iScrollObj.scrollTo(x, y, time)

你仍然可以使用iScrollObj.scrollToElement(element, time),但我认为这是更多的工作。因为element应该是CSS selectoriScroll 自动滚动到在视图顶部位置显示该元素的元素。这意味着在您附加的屏幕上会说如果您使用 的CSS selector那么Pretty row 34它会从Pretty row 34下到下显示。

请注意

Soft keyboard我使用的是我开发的(它是一个 jQuery 插件),因此我能够实现所有必需的回调函数。iScroll已经提供了很多回调函数。

因此,我能够完成我的任务,并且它正常工作,没有任何问题,正如我们预期的那样。

我不知道你有什么限制。刚刚分享了我所做的愚蠢的工作。

如果这对您来说不是一个合适的解决方案,请原谅我。

谢谢。

于 2013-06-08T04:00:09.400 回答