Conditionnellement bloc de défilement/touchmove événement dans le navigateur safari mobile

iOS 5 permet maintenant de native overflow: scroll.

Ce que je voudrais faire est de désactiver le touchmove événement pour tout, sauf les éléments qui ont le défilement de la classe ou de leurs enfants.

Mais je n'arrive pas à le faire fonctionner; c'est ce que j'ai travaillé avec ci-dessous:

<html>
<head>
<style>
.scrollable {
 height: 5em;
 overflow-y: scroll;
 -webkit-overflow-scrolling: touch;
}
</style>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<script>

//doesn't seem to work
var handleMove = function (e) {
  if (!$(e.target).parents().andSelf().hasClass('scrollable')) {
    e.preventDefault();
  }
};

document.addEventListener('touchmove', handleMove, true);

</script>
</head>
<body>
<div>
don't scroll if you drag here
</div>
<div class='scrollable'>
should be scrollable if you drag here
<ul>
<li>and here</li>
<li>and here</li>
<li>and here</li>
<li>and here</li>
<li>and here</li>
<li>and here</li>
<li>and here</li>
<li>and here</li>
</ul>
</div>
don't scroll if you drag here
</body>
</html>

OriginalL'auteur | 2011-12-22