我有2个在PC中称为click
和在Mobile语句中称为swipe
的函数。每次激活这些功能时,变量myCount
都会增加。但是问题是,当我单击移动语句上的按钮时,myCount
增加了两倍。
How do i pass variables between functions in javascript
根据上面的链接,我试图通过使用嵌套函数来传递变量,如下所示:
<!DOCTYPE html>
<html lang="en" dir="ltr">
<head>
<meta charset="utf-8">
<title></title>
<style media="screen" ref="">
* {
margin: 0;
padding: 0;
}
.page1 {
position: relative;
width: 100vw;
height: 100vh;
background-color: grey;
display: flex;
flex-flow: row;
justify-content: center;
align-items: center;
}
.buttons {
display: flex;
flex-flow: row;
justify-content: center;
align-items: center;
}
.prev {
position: absolute;
left: 0;
margin: 0 40px;
}
.shrink {
position: absolute;
flex-grow: 1.5;
}
.next {
position: absolute;
right: 0;
margin: 0 40px;
}
</style>
</head>
<body>
<div class="page1">
<div class="buttons">
<div class="button prev">Prev</div>
<div class="shrink"></div>
<div class="button next">Next</div>
</div>
</div>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script type="text/javascript">
$(function stripeAnimeModule() {
// Variables (for Click)
var _ = $('#stripe > .container > .grid > .inline-grid'),
screen = $('.page1'),
buttons = $('.page1 > .buttons > .button'),
myCount = 1,
x,
dist;
// functions
function isclicked() {
buttons.on({click: clicked})
function clicked(e) {
myCount += 1;
istouched(myCount);
}
}
function istouched(p) {
screen.bind({touchstart: touchStart, touchmove: touchMove, touchend: touchEnd})
console.log(p);
function touchStart(e) {
return x = e.touches[0].clientX;
console.log(p);
}
function touchMove(e) {
var drag = e.touches[0].clientX;
var dist = Math.sqrt(x + drag);
e.preventDefault();
}
function touchEnd(e) {
var dist = e.changedTouches[0].clientX - x;
console.log('basic log: ' + dist, myCount);
}
}
isclicked();
})
</script>
</body>
</html>
但是,如果要启动
istouched
功能,则必须首先单击按钮。之后,myCount
再次增加一倍。这是我到目前为止的方法:
<!DOCTYPE html>
<html lang="en" dir="ltr">
<head>
<meta charset="utf-8">
<title></title>
<style media="screen" ref="">
* {
margin: 0;
padding: 0;
}
.page1 {
position: relative;
width: 100vw;
height: 100vh;
background-color: grey;
display: flex;
flex-flow: row;
justify-content: center;
align-items: center;
}
.buttons {
display: flex;
flex-flow: row;
justify-content: center;
align-items: center;
}
.prev {
position: absolute;
left: 0;
margin: 0 40px;
}
.shrink {
position: absolute;
flex-grow: 1.5;
}
.next {
position: absolute;
right: 0;
margin: 0 40px;
}
</style>
</head>
<body>
<div class="page1">
<div class="buttons">
<div class="button prev">Prev</div>
<div class="shrink"></div>
<div class="button next">Next</div>
</div>
</div>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script type="text/javascript">
$(function stripeAnimeModule() {
// Variables
var screen = $('.page1'),
buttons = $('.page1 > .buttons').find('button'),
myCount = 1,
x,
dist;
// functions
$(function istouched() {
screen.bind({click: clicked, touchstart: touchStart, touchmove: touchMove, touchend: touchEnd})
function clicked(e) {
if (buttons.data('clicked', true)) {
myCount += 1;
console.log(myCount);
}
}
function touchStart(e) {
return x = e.touches[0].clientX;
}
function touchMove(e) {
var drag = e.touches[0].clientX;
var dist = Math.sqrt(x + drag);
e.preventDefault();
console.log(x, drag);
}
function touchEnd(e) {
var dist = e.changedTouches[0].clientX - x;
myCount += 1;
console.log('distance is: ' + dist, 'myCount is: '+ myCount);
}
})
})
</script>
</body>
</html>
我的期望是在2个不同的函数之间获得一个增量值
myCount
,并为下一个增量存储该值。因此,就像您第三次单击功能a
,第二次单击功能b
时,myCount
将为5,而不是3和2。有什么办法吗?
最佳答案
您可以使用Event bus pattern做到这一点,它允许您在多个不同功能之间共享数据。
的HTML
<h2>COUNT: <span data-count>0</span></h2>
<button id="btn1">Push Me 1</button><br><br>
<button id="btn2">Push Me 2</button>
JS事件总线模式
var EventManager = {
subscribe: function(event, fn) {
$(this).bind(event, fn);
},
publish: function(event) {
$(this).trigger(event);
}
};
// Register your custom code which can publish and subscribe to events
EventManager.subscribe("increaseClickSwipeValue", function() {
$('span[data-count]').text(Counter.increaseValue());
// do something other
});
// counter object which hold value
var Counter = {
value: 0,
increaseValue: function() {
this.value = this.value+1;
return this.value;
}
};
// listeners anywhere
$('#btn1').on('click', function() {
EventManager.publish("increaseClickSwipeValue");
});
$('#btn2').on('click', function() {
EventManager.publish("increaseClickSwipeValue");
});
JSFIDDLE
More about event bus