如何使用OR操作符构建事件侦听器和if语句
How to build an event listener and an if statements with an OR operator?
因为我不想写我的函数两次,如果单击.customer
或字符串'customer'是url的一部分,我想执行一些代码。
像这样:
$('.customer').click(function() {
或
if ( document.location.href.indexOf('#customer') > -1 ) {
有什么好的方法可以做到这一点?
一种方法是将将要执行的逻辑抽象到一个新函数中,然后在任何一种情况下都只调用该函数。这样做的好处是可读性和便于将来扩展(如果您想添加另一种情况,某些代码应该被执行)。
代码应该是这样的:
$(document).ready(function()
{
function logicToBeExecuted()
{
// Logic goes in here
}
if (document.location.href.indexOf('#customer') > -1 ) {
logicToBeExecuted();
}
$('.customer').click(function()
{
logicToBeExecuted();
}
});
你可以将所有将要执行的代码包装成一个函数并为每个侦听器调用该函数
$('.customer').click(function() {
myFunction();
});
if ( document.location.href.indexOf('#customer') > -1 ) {
myFunction();
});
相关文章:
- Highslide(iframe的侦听器)
- 如何在for循环中添加事件侦听器
- 选项卡侦听器未被来自后台脚本的消息激活
- 未命中服务器发送的事件侦听器
- 如何覆盖原型中的事件侦听器
- 加载侦听器上的函数触发得太早
- 无法将事件侦听器附加到画布
- 如何在d3.js中自定义事件侦听器
- 在es6中,将带有回调的事件侦听器设置为可迭代的
- 事件侦听器未在chrome扩展中的options.js中启动
- IE8更改文本区域上的事件侦听器不工作
- 将事件侦听器添加到文档,而不是签入元素存在,然后添加事件侦听器
- jQuery将侦听器的大小调整为只触发宽度的变化
- javascript删除事件侦听器
- 我应该/如何清除mousemove JQuery事件侦听器
- 在JQuery中使用谷歌地图Api事件/侦听器
- 如何在侦听器之后添加可拖动功能
- 如果侦听器附加到父元素,是否可以区分单击发生在哪个子元素上
- if.else 在 IIFy 中工作,但不在事件侦听器中工作
- 如何使用OR操作符构建事件侦听器和if语句