gpt4 book ai didi

javascript - 用Polymer让item滑回0

转载 作者:行者123 更新时间:2023-11-28 00:18:27 26 4
gpt4 key购买 nike

我试图让我的元素回到它原来的地方。拖动存储了它已经移动了多远,所以我想我可以告诉它一次回到 0 1 像素。但这不起作用(它是由 touchend 触发的)。当我查看开发工具时,我看到 {{drag}} 值是正确的,但 if 语句未触发。

如有任何帮助,我们将不胜感激。

function bounceToZero() {
if({{drag}} != 0) {
document.querySelector('pull-to-action').drag = {{drag}} - 1;
if({{drag}} != 0) {
setTimeout('bounceToZero()',1000);
}
}
}

感谢您的帮助。

编辑:这是完整的元素

<link rel="import" href="../bower_components/polymer/polymer.html">
<link rel="import" href="../bower_components/core-icons/core-icons.html">
<link rel="import" href="../bower_components/core-icon/core-icon.html">
<polymer-element attributes="action distance container color" name="pull-to-action">
<template>
<style>
:host {
display: block;
position: absolute;
width: calc(100% - 8px);
text-align:center;
z-index:99;
}
.refreshIcon {
background-color:white;
border-radius: 50%;
border: 1px solid {{color}};
padding: 8px;
top: calc(({{drag}}px - 50px) / 3);
color: {{color}};
opacity: calc({{drag}} / {{distance}});
transform: rotate({{drag}}deg);
filter: grayscale({{desat}}%);
-webkit-filter: grayscale({{desat}}%);
}
</style>
<span flex><core-icon class="refreshIcon" icon="icons:refresh"></core-icon></span>
<script>
window.addEventListener('load', function() {
var dragObs = 0;
var lastTouchY = 0;
var startTouchY = 0;
var endTouchY = 0;
var desat = 100;
var touchstartHandler = function(e) {
if (e.touches.length != 1) return;
lastTouchY = e.touches[0].clientY;
startTouchY = e.touches[0].clientY;
document.querySelector('pull-to-action').width = window.innerWidth;
}
var touchmoveHandler = function(e) {
var touchY = e.touches[0].clientY;
var touchYDelta = touchY - lastTouchY;
lastTouchY = touchY;
endTouchY = e.touches[0].clientY;
if (document.getElementById('{{container}}').scrollTop == 0) {
dragObs = endTouchY - startTouchY;
desat = 100 - ((dragObs / {{distance}}) * 100);
document.querySelector('pull-to-action').desat = desat;
document.querySelector('pull-to-action').drag = endTouchY - startTouchY;
}
if (document.getElementById('{{container}}').scrollTop == 0 && touchYDelta > 0) {
e.preventDefault();
return;
}
if (document.getElementById('{{container}}').scrollTop == 0 &&dragObs > 0) {
e.preventDefault();
return;
}
}
var touchendHandler = function(e) {
if (document.getElementById('{{container}}').scrollTop == 0 && endTouchY - startTouchY >= {{distance}}) {
{{action}};
document.querySelector('pull-to-action').drag = {{distance}};
dragObs = {{distance}}
setTimeout('bounceToZero()',2000);
} else {
function bounceToZero() {
if({{drag}} != 0) {
document.querySelector('pull-to-action').drag = {{drag}} - 1;
if({{drag}} != 0) {
setTimeout('bounceToZero()',1000);
}
}
}
}
}
document.addEventListener('touchstart', touchstartHandler, false);
document.addEventListener('touchmove', touchmoveHandler, false);
document.addEventListener('touchend', touchendHandler, false);
});
</script>
</template>
<script>
Polymer({
action: 'alert("You need to set the action attribute")',
distance: '100',
container: 'body',
drag: '0',
desat: '100',
color: '#ccc'
});
</script>
</polymer-element>

最佳答案

我认为你不能在脚本中使用模板

function bounceToZero() {
if(drag != 0) {
document.querySelector('pull-to-action').drag = drag - 1;
if(drag != 0) {
setTimeout('bounceToZero()',1000);
}
}
}

如果需要,请添加上下文进行拖动

关于javascript - 用Polymer让item滑回0,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30255358/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com